一、工作负载控制器是什么?
data:image/s3,"s3://crabby-images/4296a/4296ae07773d5834179f3edf8867381da6dfd390" alt=""
二、Deploymennt控制器:介绍与部署应用
data:image/s3,"s3://crabby-images/3375d/3375d4151d0b35f68c926e6358f1ae58591fbf69" alt=""
data:image/s3,"s3://crabby-images/aab72/aab72150421a0073eeddaea25ecfa5fac3643507" alt=""
data:image/s3,"s3://crabby-images/4ded4/4ded4c9b55856a2f9581b056a202d3a99076ce57" alt=""
部署
data:image/s3,"s3://crabby-images/182bb/182bbb740f2b48600b2cef6ef7edb56c2fb50531" alt=""
data:image/s3,"s3://crabby-images/bc876/bc876b8a9789459c27970f95c95b226e9cf80e23" alt=""
data:image/s3,"s3://crabby-images/5a89d/5a89d248f09160a8eba910a26c05708a3d4ec28a" alt=""
data:image/s3,"s3://crabby-images/dbd72/dbd72807db417985d3426fdfcdb76b17ff88dcad" alt=""
data:image/s3,"s3://crabby-images/ccabf/ccabf6379722cb9f19426e00e256292b727b54be" alt=""
data:image/s3,"s3://crabby-images/d8b96/d8b96e0df0dfae2f3063e79548f1ea3e51aa0bf0" alt=""
三、Deployment控制器:滚动升级、零停机
data:image/s3,"s3://crabby-images/3ce19/3ce19de5939bef92bace2dc4ead94e343af10eb5" alt=""
方式一:
data:image/s3,"s3://crabby-images/567d9/567d9987421ff7e19bdcb09281babbb3c2aec849" alt=""
data:image/s3,"s3://crabby-images/07650/07650804aa4e80bf71e7fa3c76b1c0384092b3f1" alt=""
data:image/s3,"s3://crabby-images/d2166/d21663047e180d9d6c90ead29656c11342ce4745" alt=""
data:image/s3,"s3://crabby-images/76e82/76e82114a97cbdc732b4d423e2f856eb76df8f88" alt=""
通个加入健康检查可以,看到,nginx容器逐个被替代,最终每个都升级完成,且发现nginx版本已经改变。
再次修改:
data:image/s3,"s3://crabby-images/dc9f6/dc9f6caf482fc62aa3d83be32dbde6bb4bf5cb6c" alt=""
data:image/s3,"s3://crabby-images/452ec/452ecf38d97a897284f4059c59b2bd171577b3e3" alt=""
通过设置延迟健康检查时间,可以更慢的看到升级过程。
也可以通过kubectl describe deployment web,查看详细事件,看到升级过程
data:image/s3,"s3://crabby-images/635fc/635fc70a95aa8bfb33671fc96c31be80adc2d330" alt=""
data:image/s3,"s3://crabby-images/566dc/566dcd77cc176dfe2266863753cdec97868096fa" alt=""
data:image/s3,"s3://crabby-images/904e6/904e6ef80ef913b5cb62d4ee18c8236ca6d30a51" alt=""
滚动更新,实质是利用了ReplicaSet控制器,时间最长的是第一次创建。一个Deployment升级时,关联了2个ReplicaSey,每次创建或更新都会创建一个新ReplicaSet,逐步将旧的副本数量降为0,新的副本数量升到配置的副本数量。
我们也可以提前配置滚动更新策略:
data:image/s3,"s3://crabby-images/0e683/0e68337b89ebbb1f5389264ccdd0fbbd023de343" alt=""
如果不指定更新策略,就是默认滚动更新策略:
data:image/s3,"s3://crabby-images/c9b65/c9b65ee29c0829280d4fe2c3c56af73205b4087a" alt=""
还记得前面的kubectl get replicaset吗?
data:image/s3,"s3://crabby-images/904e6/904e6ef80ef913b5cb62d4ee18c8236ca6d30a51" alt=""
revisionHistoryLimit - 这个对应的就是replicaset数量,默认保存最新10个。
strategy.rollingUpdate.maxSurge: 25% - 我们之前不是正常副本数设置了3个,升级的时候,你可以发现启动了1个新的,这时变为4个pod了(既3+3*0.25=3.75,不够1个算1个=4),这个参数就是用来配置,滚动更新时,Pod的最大副本数量。
strategy.rollingUpdate.maxUnavailable: 25% - 滚动更新过程中,最大不可用Pod副本数量,比如总共10个副本,一下5个副本不可用,直接导致提供并发服务不够用了。这个参数在更新过程中,确保可用Pod数量。
一般默认滚动升级策略,就足够使用了。
四、Deployment控制器 - 发布失败回滚
data:image/s3,"s3://crabby-images/a865c/a865c952ab2bc2e8081edaa402c894f6c274db39" alt=""
data:image/s3,"s3://crabby-images/df93d/df93da163353bdc71e33d178e5ca8cf3d8780a93" alt=""
这里,查看历史版本、回滚上一个版本,都没有明显标识,也不容易看出是回滚到哪个版本,所以一般升级的时候加个记录
data:image/s3,"s3://crabby-images/2eebf/2eebf013c99f11ac49386d6f7f02d375be032bac" alt=""
查看历史版本就能看的使用的命令,但是说实话,还是不是那么明显可以看出升级的内容或信息。
这是你也可以采取第二种方式来升级更新,因为升级的镜像版本在命令行中,这样升级的内容就能记录到历史版本中,如下
data:image/s3,"s3://crabby-images/d3788/d378810afbb8c5befeb742d16d086711615d6cc7" alt=""
但是在实际生产中,因为自带的回滚不是很好用,一般都是企业自己实现,说白了就是获取旧版本镜像重新部署。
还有一种方式,可以看到每个replicaset版本的内容
data:image/s3,"s3://crabby-images/0d9b7/0d9b7e355cf2675e13f37348b0155a27a7334e13" alt=""
data:image/s3,"s3://crabby-images/dcc70/dcc70f01dec2a3a83604cb6685c525a62c8fde2d" alt=""
data:image/s3,"s3://crabby-images/1ab02/1ab02eff80be21781e0203523a7810e174fa35e5" alt=""
五、Deploymeny控制器:水平扩容与ReplicaSet关系
data:image/s3,"s3://crabby-images/fc2e6/fc2e6e0ffae0f224e6ec2451938bc087ebc3b2d6" alt=""
data:image/s3,"s3://crabby-images/7cdbd/7cdbd0dae8a3f2f3ca374b4d1379a91f55ea9adc" alt=""
data:image/s3,"s3://crabby-images/3e6c9/3e6c9a618ba57e762582f7e855c4b87421cc41d6" alt=""
需要删除2个地方,1删除项目,2如果有service,需要删除service.
data:image/s3,"s3://crabby-images/ed377/ed377e783a95baeec6e475575ac3c0d6b3c0080e" alt=""
data:image/s3,"s3://crabby-images/46252/46252acce3150c89f073e7b9eef1d1e44896e6bb" alt=""
注:ReplicaSet控制器一直在死循环,这样保证Pod数量匹配配置的副本数量。
六、DaemonSet控制器:部署Node守护程序
与Deployment配置差别:
1.kind不同
2.DaemonSet不支持设置副本数量
data:image/s3,"s3://crabby-images/17b6e/17b6e52e373b71c42f4457a6a79e9c07869abac4" alt=""
data:image/s3,"s3://crabby-images/0dc8e/0dc8e77fedaf3c2616cb5d2829c88a2e4312d7e6" alt=""
data:image/s3,"s3://crabby-images/de6da/de6da1ab674cc7d5154ec28ed17d65e087f0ca20" alt=""
这里只有k8s-node1、k8s-node2两个节点起了filebeat,而k8s-master节点没有部署filebeat,这是因为k8s-master设置有污点,修改下daemonSet.yaml
data:image/s3,"s3://crabby-images/3e821/3e821d83008e89492d83dcc95cc0b12f65fcc488" alt=""
解释:
tolerations:
- effect: NoSchedule
operator: Exists
只要节点存在,就容忍。
data:image/s3,"s3://crabby-images/afbc0/afbc0a39b913a35b8b7c07fe3156082a43e0ed3e" alt=""
现在看,filebeat起了3个,k8s-master也起了一个filebeat。
七、Job控制器:执行一次性任务
data:image/s3,"s3://crabby-images/baff0/baff0e62cc02603f2145bc0064f3a8ae19b496c4" alt=""
Job本质也是一个Pod,所以如上图,也可以通过查看Pod,查看Job的运行状态。
data:image/s3,"s3://crabby-images/4f8de/4f8de523c2d95511989d242ecc3f7b9283d34df5" alt=""
注意: Job的Pod需要主动删除,因为k8s觉得这个结果可能需要保留使用,所以并没有删除。
八、CronJob控制器:定时任务
data:image/s3,"s3://crabby-images/ab27c/ab27c1e5f362dc23734f5bf9e4996fef576fb28a" alt=""
data:image/s3,"s3://crabby-images/d1992/d19928fa0a2ddab85f92656eeb3ec6e46b12b907" alt=""
注意: cronjob也不会主动删除,需要你手动删除。