3.k8s中的基本术语和概念2018-12-26

Node、Pod、Replica Controller、Service等可以看作一种资源对象,资源对象可以通过kubectl工具执行增、删、改、查等操作将其保存在etcd中持久化存储。k8s通过跟踪对比etcd库里保存的“资源期望状态”与当前环境中的“实际资源状态”的差异来实现自动控制和自动纠错。

1.master

master节点负责整个集群的管理和控制,基本上k8s的所有控制命令都发给它,负责具体的执行过程,执行的所有命令基本都是在master节点上运行的。master节点上需要启动一个etcd服务,因为k8s里所有资源对象的数据保存在etcd中。

master几点运行的关键进程:

Kubernetes API Server(kube-apiserver):所有资源增删改查等操作的入口

Kubernetes Controller Manager(kube-controller-manager):资源对象的自动控制中心

Kubernetes Scheduler(kube-scheduler):负责Pod调度的进程

2.node

Node节点可以是一台物理主机或者虚拟机,当某个Node宕机时,会被Master自动转移到其他节点上去。Node节点在运行期间可以动态的增加到k8s集群中,前提是节点已经安装和配置了关键进程。在默认情况下kbuelet会向Master注册自己,并定时汇报自身情况。

node节点的关键进程:

kubelet:负责Pod对应的容器的创建、启停等任务,与master协作,实现集群管理基本功能。

kube-proxy:实现Kubernetes Service的通信与负载机制的重要组件。

docker:负责本机的容器创建和管理工作。

3.Pod

每一个Pod都有一个Pause根容器,Pause容器对应的镜像属于Kubernetes平台的一部分

Pod有普通的Pod和静态Pod,静态Pod存放在某个具体的Node上的一个具体文件中,并且只在此Node上启动运行。普通的Pod一旦被创建,就会放到etcd中存储,随后会被Kubernetes Master调度到某个具体的Node上并进行绑定,随后该Pod被对应的Node上的kubeket进程实例化成一组相关的Docker容器并启动起来。默认情况下,当Pod里的某个容器停止时,Kubernetes会自动检测,并重新启动这个Pod,重启Pod里面的所有容器。

在Pod的yaml文件中,metadata.name为Pod的名字,matadata.labels.name为标签;spec定义了容器和对应的镜像,spec.containers.ports是在containerPort上启动容器。Pod的IP和containerPort组成了Endpoint,代表着此Pod里的一个服务进程对外的通信地址。Pod还可以设置资源限制。

4.Label

Label可以附加到各种资源对象上去,如Node、Pod、Service、RC等,一个资源对象可以定义任意数量的Label,可以通过给指定的资源对象捆绑一个或者多个不同的Label来实现多维度的资源分组管理功能,以便于灵活、方便地进行资源分配、调度等管理工作。

给某个资源对象定义一个Label,就相当于给它打了一个标签,随后可以通过Label Selector来查询和筛选拥有某些Label的资源对象,新出现的资源管理对象如Deployment、ReplicaSet、DaemonSet和Job则可以在Selector中使用基于集合的筛选条件定义。

Label Selector在Kubernetes中的重要使用场景:

--kube-controller进程通过资源对象RC上定义的Label Selector来筛选要监控的Pod副本的数量,从而实现Pod副本的数量始终符合预期设定的全自动控制流程。

--kube-proxy进程通过Service的Label Selector来选择对应的Pod,自动建立起每个Service到对应Pod的请求转发路由表,从而实现Service的智能负载均衡机制。

--通过对某些Node定义特定的Label,并且在Pod定义文件中使用NodeSelector这种标签调度策略,kube-scheduler进程可以实现Pod“定向调度”的特性。

使用Label可以给对象创建多组标签,通过Label和Label Selector使得被管理对象能够被精细地分组管理,实现整个集群的高可用性。

5.Replication Controller

定义了某种Pod的副本数量和预期值,RC定义的几个部分:

--Pod期待的副本数(replicas)

--用于筛选目标Pod的Label Selector

--创建新的Pod的模板(template)

6.Deployment

是为了解决Pod编排问题,可以看作RC的一次升级,Replica Set与Deployment可以实现Pod的自动扩容和伸缩。

7.Service

service其实就是微服务,每个Pod都会被分配一个单独的IP地址,每个Pod都提供了一个独立的Endpoint被客户端访问,多个Pod副本组成了一个集群来提供服务,负载均衡器为这组Pod开启一个对外的服务端口,并且将这些Pod的Endpoint列表加入端口的转发列表中,客户端通过负载均衡器的对外IP地址+服务端口来访问此服务。客户端的请求转发到那个Pod上,由负载均衡器(如kube-proxy)来决定,把对Service的请求转发到后端的Pod上

Pod容易发生改变,Service一旦被创建,就会分配一个可用的ClusterIP,在Service整个生命周期内不会发生改变,使用dns服务发现机制。

外部系统访问Service的问题:

--Node IP:真是存在的IP,Kubernetes集群之外的节点访问Kubernetes集群之内的节点时,必须通过NodeIP进行通信。

--Pod IP:位于不同Node上的Pod能够彼此直接通信,所以Kubernetes里一个Pod里的容器访问另外一个Pod里面的容器是通过PodIP,真是流量通过NodeIP。

--Cluster IP:Service的ClusterIP是Kubernetes内部的地址,无法外部使用。实际会有一部分服务提供给集群外部的应用或者用户使用,使用Web端的服务模块,在ports.nodePort定义端口号,使用nginx可以解决Kubernetes集群中node的负载均衡。

8.Namespace

用于实现多租户的资源隔离,Namespace通过将集群内部的资源对象“分配”到不同的Namespace中,便于不同的分组在共享使用整个集群的资源的同时还能被分别管理。如果不特别指明Namespace,用户创建的RC,Pod,Service都将被系统创建到默认的名为default的Namespace中。先用yaml文件定义Namespace,metadata.name;在创建资源对象时指定,metadata.namespace。

9.关系图


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

推荐阅读更多精彩内容