共计 1806 个字符,预计需要花费 5 分钟才能阅读完成。
这篇文章主要讲解了“如何通过 Rancher 的 webhook 微服务来实现 CI/CD 的联动”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着丸趣 TV 小编的思路慢慢深入,一起来研究和学习“如何通过 Rancher 的 webhook 微服务来实现 CI/CD 的联动”吧!
webhook 介绍
Rancher webhook 的服务流程大致如下:
router 根据用户提交过来的 method 和 url 初始化对应的 handler。
handler 解析请求参数里面的 key 和 projectid 初始化对应的 webhook driver。
driver 调用升级接口,返回并相应触发 webhook 的请求。
环境准备 Platform
Mac,Windows,Linux,Docker Cloud,AWS,Azure 均可部署。
本次准备的平台是 Ubuntu 发行版 (14.04),为了兼容 docker,选择 linux 发行版的时候内核需控制在 3.10 以上。
Docker
根据用户选择的平台安装 docker 引擎,安装指导可参考 https://docs.docker.com 官方文档,搭配 Rancher 使用,docker 引擎版本最优选择 1.12.6 或者 1.13.1。
本次准备的 docker 引擎版本是 1.12.6。
Rancher
CI/CDBuild 应用镜像
示例应用基于 NGX 官方镜像 build,修改了 NGX welcome 页面信息
Push 应用镜像
推送 NGX 应用镜像到指定的远程镜像仓库
创建 Stack Service
通过 API 创建 webapp stack,NGX service,命令行如下
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 服务,确认应用的内容。
创建 webhook
进入 webhook 创建页面,通过 UI 为 Dev,Beta,Prod 环境创建 service upgrade webhook。
(注意设置好对应的镜像 TAG 和服务标签)
更新并 push 应用镜像
更新 NGX 应用、构建镜像,并推送到远程仓库。
触发 upgrade webhook
触发 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 服务,验证服务升级内容是否正常。
感谢各位的阅读,以上就是“如何通过 Rancher 的 webhook 微服务来实现 CI/CD 的联动”的内容了,经过本文的学习后,相信大家对如何通过 Rancher 的 webhook 微服务来实现 CI/CD 的联动这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是丸趣 TV,丸趣 TV 小编将为大家推送更多相关知识点的文章,欢迎关注!