2018云栖Workshop应用发布实践手册(二)-阿里云开发者社区

开发者社区> 阿里云容器服务 ACK> 正文

2018云栖Workshop应用发布实践手册(二)

简介: 本文主要用于演示如何在阿里云容器服务Kubernetes集群中部署一个应用,并将该应用通过Ingress对外暴露提供服务访问,以及如何通过滚动升级和灰度发布来更新升级应用版本。

本文主要用于演示如何在阿里云容器服务Kubernetes集群中部署一个应用,并将该应用通过Ingress对外暴露提供服务访问,以及如何通过滚动升级和灰度发布来更新升级应用版本。

部署应用

1、首先创建一个应用部署,这里使用镜像创建
image

2、设置应用部署名称,这里取名为product-page
image

3、填写应用部署基础镜像信息
镜像:registry.cn-hangzhou.aliyuncs.com/acs-sample/productpage
版本:v1
image

4、然后创建一个对应的应用服务
image

5、待应用服务创建完成后,我们可以在服务列表中看到如下信息
image

6、最后点击创建,我们可以看到应用部署成功
image

7、查看应用详情,我们可以看到5个Pod已经成功运行
image

暴露服务

这里我们需要将product-page应用能够对外提供访问

1、创建一个路由(Ingress)
image

2、填写路由基本信息
这里我们仅填写域名前缀为product
image

3、创建完成后,我们可以看到应用的路由信息
image

4、此时我们可以通过域名访问该应用
image

滚动升级

这里我们通过滚动升级的方式来更新应用到新版本v2,由于控制台上暂未展示出应用的滚动升级进度,这里我们通过命令行的方式来操作

1、首先我们查看下前面创建成功的应用部署

  ~ kubectl get deploy
NAME           DESIRED   CURRENT   UP-TO-DATE   AVAILABLE   AGE
product-page   5         5         5            5           20m

2、在滚动升级前我们可以通过如下命令来监控整个滚动升级的过程
注意:这里不要主动停止该监控命令

  ~ kubectl get rs -w
NAME                      DESIRED   CURRENT   READY     AGE
product-page-6d74f58b46   5         5         5         1m

3、此时我们再新开一个终端,通过下面命令先主动暂停该应用的滚动升级过程,便于我们可以体验下如何主动暂停和恢复应用的滚动升级

  ~ kubectl rollout pause deploy/product-page
deployment.apps "product-page" paused

4、然后我们通过如下命令来更新应用版本到v2
镜像:registry.cn-hangzhou.aliyuncs.com/acs-sample/productpage
版本:v2

  ~ kubectl set image deploy/product-page product-page=registry.cn-hangzhou.aliyuncs.com/acs-sample/productpage:v2
deployment.apps "product-page" image updated

5、此时我们可以看到滚动升级并未开始
image

6、然后我们通过下面命令来恢复应用的滚动升级

  ~ kubectl rollout resume deploy/product-page
deployment.apps "product-page" resumed

7、此时我们看到整个的滚动升级过程
image

8、此时我们再访问应用的域名,可以看到已经是新版本的应用界面
image

9、假若我们希望回滚到老版本v1,我们首先查看下当前该应用的历史版本记录,可以看到当前有2个版本记录

  ~ kubectl rollout history deploy/product-page
deployments "product-page"
REVISION  CHANGE-CAUSE
1         <none>
2         <none>

10、我们通过如下命令来将应用回滚到revision=1的版本(即上一个版本)

  ~ kubectl rollout undo deploy/product-page
deployment.apps "product-page"

11、通过监控可以看到现在所有的Pod都回滚到了原来老版本
image

12、此时我们再次通过域名访问应用,看到了已经是老版本的页面
image

灰度发布

这里我们通过灰度发布的方式来更新应用到新版本v2

1、我们首先部署一个新版本应用v2
image

2、设置新版本应用基本信息
这里取名为product-page-v2,同样设置副本数量为5
image

3、设置使用新版本镜像v2
新镜像:registry.cn-hangzhou.aliyuncs.com/acs-sample/productpage
新版本:v2
image

4、同样创建一个新版本对应的服务
image

5、创建后,在服务列表可以看到创建了一个服务
image

6、最终创建完成,我们看到新版本v2的应用部署完成
image

7、此时我们更新路由配置来设置引流规则
image

8、这里我们设置将请求参数中带有v=2的请求转发到新版本服务中
image

9、此时我们再次访问应用域名
1)不添加请求参数v=2时
image
2)添加请求参数v=2时
image

10、最终新版本验证OK后,我们可以通过简单调整路由规则即可将全部流量引入到新版本中,这里我们仅仅保留新版本服务
image

11、此时我们再访问应用域名(不带v=2)
image

12、最后我们可以删除老版本的应用服务即可,而不会影响服务访问
image

参考文章

滚动升级:https://kubernetes.io/docs/concepts/workloads/controllers/deployment/
灰度发布:https://yq.aliyun.com/articles/594019

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

分享:
阿里云容器服务 ACK
使用钉钉扫一扫加入圈子
+ 订阅

云端最佳容器应用运行环境,安全、稳定、极致弹性

官方博客
官网链接