结合你们CI/CD的应用场景,本篇Blog旨在介绍如何经过Rancher的webhook微服务来实现CI/CD的联动。linux
本次实践的主要流程以下:nginx
Rancher webhook的服务流程大体以下:web
Mac,Windows,Linux,Docker Cloud,AWS,Azure都可部署。docker
本次准备的平台是Ubuntu发行版(14.04),为了兼容docker,选择linux发行版的时候内核需控制在3.10以上。json
示例应用基于NGX官方镜像build,修改了NGX welcome页面信息浏览器
推送NGX应用镜像到指定的远程镜像仓库app
经过API建立webapp stack,NGX service,命令行以下curl
curl -u "xxx:xxx" \ -X POST \ -H 'Accept: application/json' \ -H 'Content-Type: application/json' \ -d '{ "description": "validate the upgrade service using webhook", "name": "webapp", "system": false, "dockerCompose": "version: '2'\nservices:\n NGX:\n image: anzersy/nginx:20170801\n stdin_open: true\n tty: true\n cpuset: \"0\"\n ports:\n - 8787:80/tcp\n cpu_shares: 1024\n labels:\n io.rancher.container.pull_image: always\n servicename: nginx", "rancherCompose": "version: '2'\nservices:\n NGX:\n scale: 1\n start_on_create: true", "binding": null, "startOnCreate": true }' 'http://a.b.c.d:e/v2-beta/projects/1a107/stacks'
打开浏览器,访问NGX服务,确认应用的内容。webapp
进入webhook建立页面,经过UI为Dev,Beta,Prod 环境建立service upgrade webhook。tcp
(注意设置好对应的镜像TAG和服务标签)
更新NGX应用、构建镜像,并推送到远程仓库。
触发upgrade webhoook,实现服务自动升级。
curl -u "xxx:xxx" \ -X POST \ -H 'Accept: application/json' \ -H 'Content-Type: application/json' \ -d '{ "push_data": { "tag": "20170801" }, "repository": { "repo_name": "anzersy/nginx" } }' 'http://a.b.c.d:e/v1-
打开浏览器,访问NGX服务,验证服务升级内容是否正常。
循环3.7&3.8的步骤,完成并验证测试环境和线上环境的持续部署。
9月27日,北京海航万豪酒店,容器技术大会Container Day 2017即将举行。
CloudStack之父、海航科技技术总监、华为PaaS部门部长、恒丰银行科技部总经理、阿里云PaaS工程总监、民生保险CIO······均已加入豪华讲师套餐!
11家已容器落地企业,15位真·云计算大咖,13场纯·技术演讲,结合实战场景,聚焦落地经验。免费参会+超高规格,详细议程及注册连接请戳