基于Jenkins+OOS+OSS的自动化部署
通过Jenkins、OOS、OOS快速实现自动化部署。
本文以wordpress博客系统为例,来构建基于Jenkins + OOS的自动化部署最佳实践,示例涉及如下产品。
- wordpress github地址。
- OOS 运维编排服务,阿里云的自动化运维服务,用于管理软件版本和分批发布。
- OSS 对象存储, 用于存储构建的软件包。
- Jenkins 自动化构建,并触发更新OSS和OOS的软件包。
- ROS 资源编排服务,阿里云提供的云资源的自动化部署服务,可以帮忙您一键部署系统所依赖的云资源(ECS,RDS,SLB等)。
环境准备
WordPress云上服务器
如下步骤为通过ROS,创建了一套包含ECS和RDS的WordPress环境。
- 登录ROS(资源编排)控制台。
- 单击模板示例->模板->基于ECS和RDS创建WordPress环境->创建资源栈。
- 输入密码和实例类型等相关参数,然后单击创建,等待片刻后,若环境创建成功,资源栈的输出结果样式如下。
- 其中输出的WordPressUrl值是单机版wordpress地址,通过浏览器访问可以看到网站已经部署好。
安装并配置阿里云CLI
本文以Mac-os为例,其他系统安装可参考阿里云CLI。
- 首先为阿里云CLI创建一个RAM用户来获取AK,详细操作请参考创建RAM用户。
- 安装阿里云CLI。
brew install aliyun-cli
- 配置CLI。
aliyun configure
- 验证CLI可用,若可用,可在终端看到输出当前支持的多个地域。
aliyun ecs DescribeRegions
安装并配置Jenkins
本文示例为Mac-OS,其他系统可参考Jenkins安装。
- 安装最新版本
brew install jenkins
- 安装 LTS 版本
brew install jenkins-lts
- 启动Jinkens
brew services start jenkins-lts
Jenkins更新应用包
- 单击Newitems。
- 选择Freestyle project 并输入项目名
- 单击Source Code Managerment,选择Git地址并配置。
https://github.com/WordPress/WordPress.git
- Build内选择Add build step,添加Execute Shell步骤,配置Command贴入如下脚本,脚本功能(将wordpress master的数据打包并拷贝到oss://wordpress-test-oos路径下,然后在OOS创建名为wordpress的软件包。)
version=`date +%s`
# 打包命令
tar -cvf wordpress_$version.tar `find .|grep -v wp-config-sample.php|grep -v targets|grep -v .git|grep -v ^\.$`
# 拷贝到OSS上
/usr/local/bin/aliyun oss cp wordpress_$version.tar oss://wordpress-test-oos/wordpress_$version.tar
templateName=wordpress
# templateContent指定Location地址 并配置安装时候执行的脚本
# {
# "FormatVersion": "OOS-2020-01-01-Package",
# "Description": "",
# "Packages": [{
# "Name": "wordpress_$version.tar",
# "Location": "oss://wordpress-test-oos/wordpress_$version.tar",
# "InstallScript": "test -e wordpress || mkdir wordpress && cd wordpress && mv ../wordpress_$version.tar . && tar xvf wordpress_$version.tar > /dev/null && rm wordpress_$version.tar && cp -rf * /var/www/html/",
# "UninstallScript": "echo uninstall",
# "Targets": [{
# "PlatForm": "centos",
# "Architect": "x86_64"
# }]
# }]
# }
templateContent="{\"FormatVersion\":\"OOS-2020-01-01-Package\",\"Description\":\"\",\"Packages\":[{\"Name\":\"wordpress_$version.tar\",\"Location\":\"oss://wordpress-test-oos/wordpress_$version.tar\",\"InstallScript\":\"test -e wordpress || mkdir wordpress && cd wordpress && mv ../wordpress_$version.tar . && tar xvf wordpress_$version.tar > /dev/null && rm wordpress_$version.tar && cp -rf * /var/www/html/\",\"UninstallScript\":\"echo uninstall\",\"Targets\":[{\"PlatForm\":\"centos\",\"Architect\":\"x86_64\"}]}]}"
# 更新OOS上的软件包
/usr/local/bin/aliyun oos CreateTemplate --TemplateName=$templateName --Content "$templateContent" || /usr/local/bin/aliyun oos UpdateTemplate --TemplateName=$templateName --Content "$templateContent"
# 清理打包临时文件
rm wordpress_$version.tar
- 单击Save。
- 配置好后单击Build Now触发部署流程,然后单击Build History可查看部署情况。
- 在Console Output里我们可以看到本次部署的日志,整个过程包括从git拉取代码,执行tar打包,将包拷贝到OSS上,以及在OOS上创建(更新)一个名为wordpress的软件包,软件包在OOS控制台我的软件(注意切换地域)可查看到。
- 单击详情可查看软件的详情,包名、存储位置、安装脚本、卸载脚本,以及历史版本。
OOS部署软件
- 登录OOS控制台,单击我的软件>wordpress,单击安装软件,选择要安装在的目标实例(本示例选择上文ROS创建得到的实例id)。
- 我们发现选择实例按钮是灰色的,这个时候需要给实例配置一个角色,OOS会使用这个角色来获取软件包信息以及下载oss的权限,单击授权。
-
这时候我们跳到了添加角色的界面。
- 若有已准备好的RAM角色(应被授予AliyunOOSReadOnlyAccess及AliyunOSSReadOnlyAccess的系统权限,且信任服务为ecs云服务器),单击执行,执行列表里可以看到执行成功。
-
若无已准备好的RAM角色,参照如下步骤,创建角色。
- 登录RAM控制台,单击创建角色,授信服务选择云服务器。
- 为新建角色授予AliyunOOSReadOnlyAccess和AliyunOSSReadOnlyAccess。
- 回到为批量操作实例-实例操作-添加角色,完成实例的角色授予。
- 实例配置好角色后,回到我的软件执行安装软件,选择已授予instanceRole的实例,配置完后,单击立即执行。
- 最后我们看到执行结果成功了,并且机器上的wordpress /var/www/html里的内容也变成了最新的,在执行详情可查看具体信息。
总结
以上我们完成了基于OOS+Jenkins的CICD流程,通过OOS我的软件功能,可以进行软件版本的管理和应用分批部署,在Jenkins中,也支持设置为直接调用OOS我的软件自动安装,以此来完成部署的全自动化,后续我们还将介绍如何用OOS+Jenkins自动更新镜像。