从一条命令出发,了解k8s组件的作用

Docker和k8s作为近些年来兴起的容器技术代表,已经被越来越多的公司作为服务运维的方式。但是作为一名爱技术的程序员,对于k8s的理解仅仅停留在会模仿写一下cm、service和deployment这几个yml文件,那是远远不够的。今天从一条命令kubectl run nginx --image=nginx出发,给大家分享一下k8s的构成组件。
故事的开篇从官网的一张图开始,作为k8s组件的总览。后面会根据kubectl命令的执行依次说明每个组件的作用。

The components of a Kubernetes cluster

整个图分为三大部分:1、Control Plane;2、Node;3、Cloud provider API
其中,Control Plane包含:kube-apiserver(api)、etcd、kube-scheduler(sched)、kube-controller-manager(c-m)、cloud-controller-manager(c-c-m),Node里包括:kubelet、kube-proxy。
在讲kubectl命令在k8s集群流转链路前,我们首先需要知道k8s集群中的每台机器叫做Node,而Node分为两大类:一个是Master,一个是Worker。虽然没有强制说明Master机器上不能运行Pod,但是在k8s官网中不建议我们这样做。

Control plane components can be run on any machine in the cluster. However, for simplicity, set up scripts typically start all control plane components on the same machine, and do not run user containers on this machine.
翻译:Control Plane组件可以在群集中的任何机器上运行。但是,为了简单起见,启动脚本通常在同一台机器上启动所有Control Plane组件,并且不在此机器上运行用户容器。

下面,我们从kubectl run nginx --image=nginx这条命令出发,看看到底发生了什么。
首先,用户在shell中敲出这段命令并回车,kubectl客户端会将这条命令封装成一个HTTP请求,发到Control Plane中的kube-apiserver组件,这个组件你可以理解为整个k8s集群的入口,任何外部的操作请求都需要经过它。kube-apiserver在收到这个请求后,首先会对其进行参数以及合法性校验,比如语句语法是否正确、请求命令希望操作的资源是否合法等。在校验通过后,会将这条命令存储到Control Plane里的另一个重要组件etcd中。
一旦存储到etcd,那么就会被Control Plane里的kube-controller-manager组件检测到,这个组件的作用主要是针对etcd中的命令内容,开始构建指定的资源,比如构建deployment、replicaSet等,资源构建完成后,将相关信息更新到etcd中。但是请注意,到这里只是构建资源,还并没有真正的运行nginx这个pod,或者说,还早得很!!!
当kube-controller-manager将对应资源构建完成,并更新到etcd后,Control plane里的另一个组件kube-scheduler就派上用场。他同样会检测到etcd中的变更,根据变更信息开始执行调度,比如将服务部署到哪个Node。对于Node的选择,kube-scheduler有一套自己的策略,这里不做深究,总之它能够根据你的命令,选择到合适的Node,将服务调度到对应的Node。调度完成的标志依然是更新NodeName到etcd中,可能大家也注意到了,其实在这一步,服务依然没有在Worker Node上启动,依然是etcd的更新操作,容器处于pending状态!
那么Worker Node是怎么感知到我这个Node上需要启动一个Pod的呢?
这就需要Node里的kubelet组件登场了!!!它会检测到etcd中关于自身Node的信息,并对Node上已经存在的容器进行对比,发现差异后执行对应的操作,到这一步才真正的在Node上启动了Pod!!!
大功告成!!!

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,047评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,807评论 3 386
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,501评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,839评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,951评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,117评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,188评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,929评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,372评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,679评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,837评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,536评论 4 335
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,168评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,886评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,129评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,665评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,739评论 2 351

推荐阅读更多精彩内容