在线精品99_中国九九盗摄偷拍偷看_91免费版在线观看_91.app_91高清视频在线_99热最新网站

基于 Kubernetes如何实现滚动发布

122次阅读
没有评论

共计 2809 个字符,预计需要花费 8 分钟才能阅读完成。

这篇文章将为大家详细讲解有关基于 Kubernetes 如何实现滚动发布,文章内容质量较高,因此丸趣 TV 小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

前言

软件世界比以往任何时候都更快。为了保持竞争力,需要尽快推出新的软件版本,而不会中断活跃用户访问,影响用户体验。越来越多企业已将其应用迁移到 Kubernetes。

在 Kubernetes 中有几种不同的方式发布应用,所以为了让应用在升级期间依然平稳提供服务,选择一个正确的发布策略就非常重要了,丸趣 TV 小编将讲解如何在 Kubernetes 使用滚动更新的方式更新镜像。

原理

策略定义为 RollingUpdate 的 Deployment。滚动更新通过逐个替换实例来逐步部署新版本的应用,直到所有实例都被替换完成为止,会有新版旧版同时存在的情况。

spec:
 replicas: 4
 strategy:
 type: RollingUpdate
 rollingUpdate:
 maxSurge: 0 #  决定了配置中期望的副本数之外,最多允许超出的  pod  实例的数量
 maxUnavailable: %25 #  决定了在滚动升级期间,相对于期望副本数能够允许有多少  pod  实例处于不可用状态 

上述更新策略执行结果如下图所示

基于 Kubernetes 如何实现滚动发布

实践使用 Kubernetes 原生方式升级应用准备

image

bebullish/demo:v1
bebullish/demo:v2

deployment

apiVersion: apps/v1
kind: Deployment
metadata:
 name: demo-dp
spec:
 selector:
 matchLabels:
 app: demo
 replicas: 3
 strategy:
 type: RollingUpdate
 rollingUpdate:
 maxSurge: 25%
 maxUnavailable: 25%
 template:
 metadata:
 labels:
 app: demo
 spec: 
 containers:
 - name: demo
 image: bebullish/demo:v1
 ports:
 - containerPort: 8080

service

apiVersion: v1
kind: Service
metadata:
 name: demo-service
spec:
 selector:
 app: demo
 type: LoadBalancer
 ports:
 - port: 80
 targetPort: 8080
 protocol: TCP

将上述 deployment 以及 service 保存为 yaml 文件,使用 kubectl apply -f 命令创建 yaml 资源,等待创建成功后,使用 kubectl get svc 获取 EXTERNAL-IP。

测试

如果使用浏览器测试的话,你会发现每次调用都会返回同一个 pod 的名字,那是因为浏览器发出的请求包含 keepAlive,所以需要使用 curl 来保证每次发出的请求都是重新创建的。

curl -X GET http://${EXTERNAL-IP}

基于 Kubernetes 如何实现滚动发布

升级

升级之前先执行命令,以便查看镜像更新过程

while true; do curl -X GET http://${EXTERNAL-IP} ; done

更新镜像

kubectl set image deployment demo-dp demo=bebullish/demo:v2

查看日志

基于 Kubernetes 如何实现滚动发布

请求流量

基于 Kubernetes 如何实现滚动发布

结论

首先可以发现在更新过程中,程序保持一直可用的状态,在出现了 v2 版本之后,还会出现 v1 版本的日志,说明在这个期间 v1 和 v2 版本是同时存在的,等到 v2 版本的 pod 全部处于就绪状态之后,可以看到所有的请求就都是 v2 版本的了。

使用 CODING CD 方式升级应用配置制品

基于 Kubernetes 如何实现滚动发布

使用 docker 官方镜像需要以 docker.io 开头

配置 yaml 及绑定制品

基于 Kubernetes 如何实现滚动发布

deployment

apiVersion: apps/v1
kind: Deployment
metadata:
 name: demo-dp
spec:
 selector:
 matchLabels:
 app: demo
 replicas: 3
 strategy:
 type: RollingUpdate
 rollingUpdate:
 maxSurge: 25%
 maxUnavailable: 25%
 template:
 metadata:
 labels:
 app: demo
 spec: 
 containers:
 - name: demo
 image: docker.io/bebullish/demo
 ports:
 - containerPort: 8080
 readinessProbe:
 httpGet:
 path: /
 port: 8080
 initialDelaySeconds: 30 #  延迟  30  秒检测,以便更好的观察更新过程
 periodSeconds: 5
 livenessProbe:
 httpGet:
 path: /
 port: 8080
 initialDelaySeconds: 30 #  延迟  30  秒检测,以便更好的观察更新过程
 periodSeconds: 5
 terminationGracePeriodSeconds: 1 #  处于  Terminating  状态多久后,强制杀死  pod

阶段中选择 部署(Manifest),输入上述 yaml 文件(主要增加了就绪探针和存活探针),这里需要把镜像的版本删除掉,在需要绑定的制品选择之前配置的制品。这样配置之后,每次执行的时候版本是动态传入的。

发布制品

基于 Kubernetes 如何实现滚动发布

选择应用和部署流程,输入版本 v1。

查看结果

基于 Kubernetes 如何实现滚动发布

等待一小段时间后,就可以在部署控制台中看到发布的资源了。

更新镜像版本

基于 Kubernetes 如何实现滚动发布

再次执行发布,版本输入 v2。

更新过程

基于 Kubernetes 如何实现滚动发布

可以看到此时 v2 版本的 pod 有一个正在启动,而 v1 版本的 pod 全部处于就绪状态。

基于 Kubernetes 如何实现滚动发布

v2 版本的 pod 有一个已经就绪,同时正在启动另一个新的 pod,与此同时 v1 版本的有一个 pod 已经关机了,而另外两个 pod 仍处于就绪状态。

基于 Kubernetes 如何实现滚动发布

v2 版本的 pod 有两个已经就绪,同时正在启动最后一个新的 pod,与此同时 v1 版本的有两个 pod 已经关机了,而另外一个 pod 仍处于就绪状态。

基于 Kubernetes 如何实现滚动发布

v2 版本的 pod 已经全部处于就绪状态了,同时 v1 版本的 pod 已经全部关机,至此,一次滚动更新结束。

使用 Kubernetes 原生方式实现滚动更新更加简单方便,但也容易出错(人工),推荐使用 coding.net 提供的 CD 功能,配置一次,永久使用。不仅可以直观的观察到 pod 更新过程,还提供了非常丰富的 CD 功能。

关于基于 Kubernetes 如何实现滚动发布就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

正文完
 
丸趣
版权声明:本站原创文章,由 丸趣 2023-08-25发表,共计2809字。
转载说明:除特殊说明外本站除技术相关以外文章皆由网络搜集发布,转载请注明出处。
评论(没有评论)
主站蜘蛛池模板: 日本黄大片 在线播放 | 99热热久久这里只有精品166 | 久久99精品视频 | 久久久网| 四虎精品8848ys一区二区 | 无码国产偷倩在线播放老年人 | 成年日韩片av在线网站 | 午夜影院入口 | 国产男女做爰高清全过小说 | 美女张开腿让男人桶视频 | 亚洲人成伊人成综合网久久 | 欧美日韩日本国产 | 国产成人亚洲精品91专区高清 | www.国产精品 | 国产午夜视频在线观看第四页 | 久久精品国产亚洲沈樵 | 九九精品在线视频 | 国产 字幕 制服 中文 在线 | 日本爽快片毛片 | 护士奶头又白又大又好摸视频 | 精品女同一区二区三区在线 | 人人爽人人爽人人爽人人片av | 中文字幕不卡一区 | 自拍视频免费 | 成人国产免费 | 男人天堂免费 | 999久久欧美人妻一区二区 | 久久亚洲国产成人精品无码区 | 80岁老妇xxxxx高清 | 亚洲欧美视频在线 | 日本久久久久久 | 欧美激情综合色综合啪啪五月 | 人妻少妇看a偷人无码 | h人成在线看免费视频 | 老司机在线观看免费视频 | 色先锋资源久久综合5566 | 久久精品国产只有精品2020 | 久久国产免费观看精品 | 欧美精彩视频在线观看 | 国产精品爽爽久久久久久竹菊 | 一级毛片免费视频观看 |