Kubernetes 控制器

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

Deployment

Deployment 为 Pod 和 ReplicaSet(副本集) 提供了一个声明式定义(declarative)方法,用来替代以前的Replication Controller 但是它又具备了Replication Controller之外的新特性,来方便管理应用.

replication controller与deployment的区别:

replication controller特性:

 ● 确保pod数量:它会确保Kubernetes中有指定数量的Pod在运行。如果少于指定数量的pod,Replication Controller会创建新的,反之则会删除掉多余的以保证Pod数量不变。

 ● 确保pod健康:当pod不健康,运行出错或者无法提供服务时,Replication Controller也会杀死不健康的pod,重新创建新的。

 ● 弹性伸缩 :在业务高峰或者低峰期的时候,可以通过Replication Controller动态的调整pod的数量来提高资源的利用率。同时,配置相应的监控功能(Hroizontal Pod Autoscaler),会定时自动从监控平台获取Replication Controller关联pod的整体资源使用情况,做到自动伸缩。

 ● 滚动升级:滚动升级为一种平滑的升级方式,通过逐步替换的策略,保证整体系统的稳定,在初始化升级的时候就可以及时发现和解决问题,避免问题不断扩大。

Deployment特性:

 ● Deployment可以看做新一代的Replication Controller。除继承所有Replication Controller特性外,它又增加了Replication Controller之外的一些新特性:

 ● 回滚:当升级pod镜像或者相关参数的时候发现问题,可以使用回滚操作回滚到上一个稳定的版本或者指定的版本

 ● 版本记录: 每一次对Deployment的操作,都能保存下来,给予后续可能的回滚使用

 ● 暂停和启动:对于每一次升级,都能够随时暂停和启动

 ● 多种升级方案:
   Recreate:删除所有已存在的pod,重新创建新的;
   RollingUpdate:滚动升级,逐步替换的策略,同时滚动升级时,支持更多的附加参数,例如设置最大不可用pod数量,最小升级间隔时间等等.

deployment的常用命令:

猜你喜欢

转载自www.cnblogs.com/saneri/p/9469929.html