[关闭]
@zhangyy 2020-03-07T17:28:46.000000Z 字数 6032 阅读 172

Kubernetes 中的控制器

kubernetes系列


  • 一:kubernetes 中控制器
  • 二:kubernetes 类型

一:kubernetes 中控制器

1.1 生命是控制器

  1. Kubernetes 中内建了很多 controller(控制器),这些相当于一个状态机,用来控制 Pod 的具体状态和行为

1.2 控制器类型

  1. ReplicationController ReplicaSet
  2. Deployment
  3. DaemonSet
  4. StateFulSet
  5. Job/CronJob
  6. Horizontal Pod Autoscaling

1.2.1 ReplicationController 和 ReplicaSet

  1. ReplicationControllerRC)用来确保容器应用的副本数始终保持在用户定义的副本数,即如果有容器异常退
  2. 出,会自动创建新的 Pod 来替代;而如果异常多出来的容器也会自动回收;
  3. 在新版本的 Kubernetes 中建议使用 ReplicaSet 来取代 ReplicationController ReplicaSet
  4. ReplicationController 没有本质的不同,只是名字不一样,并且 ReplicaSet 支持集合式的 selector 标签

1.2.2 Deployment

  1. Deployment Pod ReplicaSet 提供了一个声明式定义 (declarative) 方法,用来替代以前的
  2. ReplicationController 来方便的管理应用。典型的应用场景包括;
  3. 定义 Deployment 来创建 Pod ReplicaSet
  4. 滚动升级和回滚应用
  5. 扩容和缩容
  6. 暂停和继续 Deployment
  7. 编程:
  8. 命令式编程:它侧重于如何实现程序,就像我们刚接触编程的时候那样,我们需要把程序的实现过程按照逻辑结果一步步写下来
  9. 声明式编程:它侧重于定义想要什么,然后告诉计算机/引擎,让他帮你去实现
  10. 结构化的查询语句(T-sql
  11. 申明式编程 Deployment apply(优) create
  12. 命令式 rs create(优) apply

  1. RS RC Deployment 关联:
  2. RC ReplicationController )主要的作用就是用来确保容器应用的副本数始终保持在用户定义的副本数 。即如
  3. 果有容器异常退出,会自动创建新的Pod来替代;而如果异常多出来的容器也会自动回收
  4. Kubernetes 官方建议使用 RSReplicaSet 替代 RC ReplicationController 进行部署,RS RC 没有
  5. 本质的不同,只是名字不一样,并且 RS 支持集合式的 selector
  1. vim rs-deploy.yaml
  2. ---
  3. apiVersion: extensions/v1beta1
  4. kind: ReplicaSet
  5. metadata:
  6. name: frontend
  7. spec:
  8. replicas: 3
  9. selector:
  10. matchLabels:
  11. tier: frontend
  12. template:
  13. metadata:
  14. labels:
  15. tier: frontend
  16. spec:
  17. containers:
  18. - name: myapp
  19. image: wangyanglinux/myapp:v1
  20. env:
  21. - name: GET_HOSTS_FROM
  22. value: dns
  23. ports:
  24. - containerPort: 80
  25. ---
  26. kubectl apply -f rs-deploy.yaml
  27. kubectl get pods

image_1e2pcesd11g6smi51n5kr4riah1t.png-205.3kB

image_1e2pcfd5s1rvatdg1st01lcd1mg92a.png-159.4kB

image_1e2pcj1aj1591cde5eb1r75rj42n.png-228.4kB

  1. 总结: 很多的rs 是标签来控制的 一旦 rs 被删除 pod 所对应的 定义标签 pod都会被删除
  1. RS Deployment 的关联

image_1e2pcnq5m1llc142gousvl914534.png-59.1kB

  1. 部署一个nginx
  2. vim nginx-deploy.yaml
  3. ----
  4. apiVersion: extensions/v1beta1
  5. kind: Deployment
  6. metadata:
  7. name: nginx-deployment
  8. spec:
  9. replicas: 3
  10. template:
  11. metadata:
  12. labels:
  13. app: nginx
  14. spec:
  15. containers:
  16. - name: nginx
  17. image: wangyanglinux/myapp:v1
  18. ports:
  19. - containerPort: 80
  20. ---
  21. kubectl apply -f nginx-deploy.yaml --recond
  22. ## --record参数可以记录命令,我们可以很方便的查看每次 revision 的变化
  23. kubectl get pod
  24. kubectl get deploy

image_1e2pdk744j8g1bnlg3p1ugvirs3h.png-107.9kB

image_1e2pdlq411vlevonavjtr11ne53u.png-163kB

image_1e2pdpvv81euf18ohcb7148u1on84b.png-173.9kB

  1. 扩容方案:
  2. kubectl scale deployment nginx-deployment --replicas 5

image_1e2pe0tqi6ak1u5e1f18l08vpk5l.png-194.1kB

  1. 如果集群支持 horizontal pod autoscaling 的话,还可以为Deployment设置自动扩展
  2. kubectl autoscale deployment nginx-deployment --min=10 --max=15 --cpu-percent=80

  1. 更新镜像也比较简单
  2. kubectl set image deployment/nginx-deployment nginx=wangyanglinux/myapp:v2

image_1e2peo08etv5ctl1lm1ocl1poq62.png-42.8kB

image_1e2peoh521efo1h6g1qnm1di61v956f.png-86.3kB

image_1e2pep8h21u8qqu117f4jctsn57c.png-34.1kB

image_1e2pepru3eihfqv12qard8unf7p.png-82.3kB

image_1e2pergj49uas6rqocphkfub86.png-184kB

  1. 回滚:
  2. kubectl rollout undo deployment/nginx-deployment

image_1e2pf2b375isf4n17rm7ud1ovk8j.png-234.9kB


  1. 详细的回滚更新操作:
  2. kubectl set image deployment/nginx-deployment nginx=wangyanglinux:v2
  3. kubectl rollout status deployments nginx-deployment
  4. kubectl get pods
  5. kubectl rollout history deployment/nginx-deployment
  6. kubectl rollout undo deployment/nginx-deployment
  7. kubectl rollout undo deployment/nginx-deployment --to-revision=2 ## 可以使用 --revision参数指定
  8. 某个历史版本
  9. kubectl rollout pause deployment/nginx-deployment ## 暂停 deployment 的更新

image_1e2pftl471vte1gv41iie1feljcs9d.png-237.1kB

image_1e2pfv6q617ai12151i9dapo6b89q.png-215.1kB

image_1e2pfvkpbotm1phrs9m1a4a136ua7.png-197.4kB

image_1e2pg0vlpt6h12ot6o71ba7b2vak.png-235.5kB

image_1e2ph9g9b1mm46o1a7v17hqjeobe.png-202.7kB

image_1e2pha4op1n2k1sb7pqc1crvfbbbr.png-76.4kB

  1. 可以用 kubectl rollout status 命令查看 Deployment 是否完成。如果 rollout 成功完成, kubectl rollout
  2. status 将返回一个0值的 Exit Code
  3. $ kubectl rollout status deployment/nginx-deployment
  4. Waiting for rollout to finish: 2 of 3 updated replicas are available...
  5. deployment "nginx" successfully rolled out
  6. $ echo $?
  7. 0
  8. 上面的 返回码,这个一般用于写脚本
  1. 清理 Policy
  2. 您可以通过设置 .spec.revisonHistoryLimit 项来指定 deployment 最多保留多少 revision 历史记录。默认的会
  3. 保留所有的 revision;如果将该项设置为0Deployment 就不允许回退了

1.2.3 DaemonSet

  1. DaemonSet 确保全部(或者一些)Node 上运行一个 Pod 的副本。当有 Node 加入集群时,也会为他们新增一个
  2. Pod 。当有 Node 从集群移除时,这些 Pod 也会被回收。删除 DaemonSet 将会删除它创建的所有 Pod
  3. 使用 DaemonSet 的一些典型用法:
  4. 运行集群存储 daemon,例如在每个 Node 上运行 glusterd ceph
  5. 在每个 Node 上运行日志收集 daemon,例如 fluentd logstash
  6. 在每个 Node 上运行监控 daemon,例如 Prometheus Node Exporter collectd Datadog 代理、
  7. New Relic 代理,或 Ganglia gmond
  8. 守护进程 方案

  1. vim daemonset.yaml
  2. ----
  3. apiVersion: apps/v1
  4. kind: DaemonSet
  5. metadata:
  6. name: deamonset-example
  7. labels:
  8. app: daemonset
  9. spec:
  10. selector:
  11. matchLabels:
  12. name: deamonset-example
  13. template:
  14. metadata:
  15. labels:
  16. name: deamonset-example
  17. spec:
  18. containers:
  19. - name: daemonset-example
  20. image: wangyanglinux/myapp:v1
  21. ----
  22. kubectl apply -f daemonset.yaml
  23. kubectl get daemonset
  24. kubectl delete daemonset --all

image_1e2q124sf1ksg1deo1criu82l8cl.png-252.8kB

image_1e2q15sgvue5slfglit09p1mdi.png-274.7kB

image_1e2q4nr691umhd6eic5td1tkfhd.png-163kB

1.2.4 Job

  1. Job 负责批处理任务,即仅执行一次的任务,它保证批处理任务的一个或多个 Pod 成功结束
  2. 特殊说明:
  3. spec.template格式同Pod
  4. RestartPolicy仅支持NeverOnFailure
  5. 单个Pod时,默认Pod成功运行后Job即结束
  6. .spec.completions 标志Job结束需要成功运行的Pod个数,默认为1
  7. .spec.parallelism 标志并行运行的Pod的个数,默认为1
  8. spec.activeDeadlineSeconds
  9. 标志失败Pod的重试最大时间,超过这个时间不会继续重试

  1. 上传 镜像 Perl.tar.gz 到全部节点
  2. tar -zxvf Perl.tar.gz
  3. docker load -i perl.tar
  4. docker tag perl:latest perl:v1
  5. --------------------
  6. vim job.yaml
  7. ----
  8. apiVersion: batch/v1
  9. kind: Job
  10. metadata:
  11. name: pi
  12. spec:
  13. template:
  14. metadata:
  15. name: pi
  16. spec:
  17. containers:
  18. - name: pi
  19. image: perl:v1
  20. command: ["perl", "-Mbignum=bpi", "-wle", "print bpi(2000)"]
  21. restartPolicy: Never
  22. ---
  23. 查看日志 表示 运行计算pi 2000
  24. kubectl apply -f job.yaml

image_1e2q2pnd21hpskrl48msjaahvec.png-201.4kB

image_1e2q2qsbl1fdr1qi713p138g921ep.png-227.6kB

image_1e2q2rr968vnb1e16d9i65j7cf6.png-143.5kB

image_1e2q2k1l7q7417e11au81se31abqdv.png-154.2kB

image_1e2q2ubf71pgtlku1sd01s81nalfj.png-234.4kB

1.2.5 CronJob

  1. Cron Job 管理基于时间的 Job,即:
  2. 在给定时间点只运行一次
  3. 周期性地在给定时间点运行
  4. 使用前提条件:
  5. **当前使用的 Kubernetes 集群,版本 >= 1.8(对 CronJob)。对于先前版本的集群,版本 <1.8,启动 API Server时,通过传递选项  --runtime-config=batch/v2alpha1=true  可以开启 batch/v2alpha1
  6. API**
  7. 典型的用法如下所示:
  8. 在给定的时间点调度 Job 运行
  9. 创建周期性运行的 Job,例如:数据库备份、发送邮件

  1. CronJob Spec:
  2. spec.template格式同Pod
  3. RestartPolicy仅支持NeverOnFailure
  4. 单个Pod时,默认Pod成功运行后Job即结束
  5. .spec.completions 标志Job结束需要成功运行的Pod个数,默认为1
  6. .spec.parallelism 标志并行运行的Pod的个数,默认为1
  7. spec.activeDeadlineSeconds 标志失败Pod的重试最大时间,超过这个时间不会继续重试

  1. .spec.schedule :调度,必需字段,指定任务运行周期,格式同 Cron
  2. .spec.jobTemplate Job 模板,必需字段,指定需要运行的任务,格式同 Job
  3. .spec.startingDeadlineSeconds :启动 Job 的期限(秒级别),该字段是可选的。如果因为任何原因而错
  4. 过了被调度的时间,那么错过执行时间的 Job 将被认为是失败的。如果没有指定,则没有期限
  5. .spec.concurrencyPolicy :并发策略,该字段也是可选的。它指定了如何处理被 Cron Job 创建的 Job
  6. 并发执行。只允许指定下面策略中的一种:
  7. Allow (默认):允许并发运行 Job
  8. Forbid :禁止并发运行,如果前一个还没有完成,则直接跳过下一个
  9. Replace :取消当前正在运行的 Job,用一个新的来替换
  10. 注意,当前策略只能应用于同一个 Cron Job 创建的 Job。如果存在多个 Cron Job,它们创建的 Job 之间总
  11. 是允许并发运行。
  12. .spec.suspend :挂起,该字段也是可选的。如果设置为 true ,后续所有执行都会被挂起。它对已经开始
  13. 执行的 Job 不起作用。默认值为 false
  14. .spec.successfulJobsHistoryLimit .spec.failedJobsHistoryLimit :历史限制,是可选的字段。它
  15. 们指定了可以保留多少完成和失败的 Job。默认情况下,它们分别设置为 3 1 。设置限制的值为 0 ,相
  16. 关类型的 Job 完成后将不会被保留。

  1. vim cronjob.yaml
  2. ---
  3. apiVersion: batch/v1beta1
  4. kind: CronJob
  5. metadata:
  6. name: hello
  7. spec:
  8. schedule: "*/1 * * * *"
  9. jobTemplate:
  10. spec:
  11. template:
  12. spec:
  13. containers:
  14. - name: hello
  15. image: busybox
  16. args:
  17. - /bin/sh
  18. - -c
  19. - date; echo Hello from the Kubernetes cluster
  20. restartPolicy: OnFailure
  21. ----
  22. kubectl apply -f cronjob.yaml
  23. kubectl get cronjob
  24. kubectl get job

image_1e2q44dmiit5182412g7p8pr5ng0.png-172.9kB

image_1e2q46evpchkl01rkf1oknbnhgt.png-228.9kB

1.2.6 StatefulSet

  1. StatefulSet 作为 Controller Pod 提供唯一的标识。它可以保证部署和 scale 的顺序
  2. StatefulSet是为了解决有状态服务的问题(对应DeploymentsReplicaSets是为无状态服务而设计),其应用场景包括:
  3. 1.稳定的持久化存储,即Pod重新调度后还是能访问到相同的持久化数据,基于PVC来实现
  4. 2. 稳定的网络标志,即Pod重新调度后其PodNameHostName不变,基于Headless
  5. Service(即没有Cluster IPService)来实现
  6. 3. 有序部署,有序扩展,即Pod是有顺序的,在部署或者扩展的时候要依据定义的顺序依次依次进行(即从0N-1,在下一个Pod运行之前所有之前的Pod必须都是RunningReady状态),基于init containers来实现
  7. 4. 有序收缩,有序删除(即从N-10

1.2.7 Horizontal Pod Autoscaling

  1. 应用的资源使用率通常都有高峰和低谷的时候,如何削峰填谷,提高集群的整体资源利用率,让service中的Pod
  2. 个数自动调整呢?这就有赖于Horizontal Pod Autoscaling了,顾名思义,使Pod水平自动缩放
添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注