Jenkins入门
第0章 Jenkins介绍
1.jenkins是一个开源的持续集成工具,由java语言开发
2.jenkins是一个调度平台,拥有众多的插件,绝大部分功能都是由插件来完成的
第1章 Jenkins安装
1.官方网站
https://www.jenkins.io/zh/
https://www.jenkins.io/zh/doc/
2.安装部署
清华源直接下载rpm包安装即可,下载地址如下:
https://mirrors.tuna.tsinghua.edu.cn/jenkins/redhat/
安装命令如下:
rpm -ivh jdk-8u181-linux-x64.rpm
rpm -ivh jenkins-2.176.1-1.1.noarch.rpm
3.目录文件说明
[root@jenkins ~]# rpm -ql jenkins
/etc/init.d/jenkins #启动文件
/etc/logrotate.d/jenkins #日志切割脚本
/etc/sysconfig/jenkins #配置文件
/usr/lib/jenkins #安装目录
/usr/lib/jenkins/jenkins.war #安装包
/usr/sbin/rcjenkins
/var/cache/jenkins
/var/lib/jenkins #数据目录
/var/log/jenkins #日志目录
4.配置使用root账户运行
vim /etc/sysconfig/jenkins
JENKINS_USER="root"
5.启动jenkins
systemctl start jenkins
6.解锁Jenkins
data:image/s3,"s3://crabby-images/e08b8/e08b8ef2b4344f5af06f1989313f7a7d4228c8e8" alt=""
7.修改admin密码
data:image/s3,"s3://crabby-images/3ff99/3ff99e621f77af6801897b5892d866b6924b657d" alt=""
8.使用清华源作为插件地址
清华源地址:
https://mirrors.tuna.tsinghua.edu.cn/jenkins/updates/update-center.json
配置步骤:
data:image/s3,"s3://crabby-images/b7fdf/b7fdf1e4faa4282440c0c13797f7dce7b588c3c3" alt=""
data:image/s3,"s3://crabby-images/ac627/ac627cbc98151213b8b6fb0a53e56c4488b22060" alt=""
data:image/s3,"s3://crabby-images/eb3f5/eb3f54cf00b5adf414b21340f118431aab1fd6d7" alt=""
data:image/s3,"s3://crabby-images/7dc13/7dc133733f144cfb24443c1eb1cf5a401142f0a4" alt=""
9.使用离线安装插件
我们可以将插件提前下好,然后只需要解压到jenkins对应的目录即可
tar zxf jenkins_plugins.tar.gz -C /var/lib/jenkins/
ll /var/lib/jenkins/plugins/
重启jenkins:
systemctl restart jenkins
第2章 构建自由风格的项目
1.创建新任务
data:image/s3,"s3://crabby-images/8d862/8d8627a91437b39c86bf1b6aba96dd993f93fe89" alt=""
data:image/s3,"s3://crabby-images/1befa/1befa2ee1b086f46418b99e7f538cbfca68a559c" alt=""
data:image/s3,"s3://crabby-images/68762/6876261e9c5b19117e425665aa0f5b8aecd5fb1b" alt=""
2.添加构建步骤
data:image/s3,"s3://crabby-images/dabb7/dabb780eb35777e4c213abd8a3f655db4b9c1035" alt=""
data:image/s3,"s3://crabby-images/389b3/389b39cba53cc19e17c6112052d0e72e221aa7dd" alt=""
3.点击立即构建
data:image/s3,"s3://crabby-images/a1ba2/a1ba24c1fc2115eafcfe3a999d24ad493b0fbf17" alt=""
4.查看控制台输出
data:image/s3,"s3://crabby-images/bbaaf/bbaaf7b7989f48b35d3862baed1ef3a905ef1559" alt=""
data:image/s3,"s3://crabby-images/743ef/743ef47aa94734baeb76d1f6c4436f69ff7f6f6b" alt=""
第3章 发布gitlab中的静态项目
1.gitlab导入工程
这是一个h5小游戏的项目,项目地址:
https://gitee.com/skips/game.git
使用gitlab直接导入项目:
data:image/s3,"s3://crabby-images/99df3/99df3a3e5a45cab14bc8fa4dc73a9e2ed83f05f5" alt=""
data:image/s3,"s3://crabby-images/50c79/50c79035b303ff5845511d82a8584c7b0f85a301" alt=""
data:image/s3,"s3://crabby-images/16824/16824b2310f6e9f48d6546367c729ed4f4c9baa4" alt=""
data:image/s3,"s3://crabby-images/212e8/212e8abcf26e6fc383fbf2d1efaa7d2d153c9185" alt=""
data:image/s3,"s3://crabby-images/9aca7/9aca7e5387ace17dc56f2e5677b8a17769514d2b" alt=""
2.在jenkins中关联gitlab的h5game项目
2.1 创建新项目
data:image/s3,"s3://crabby-images/282d4/282d4d1608fb03397ca0bcf4945fa4381d23c096" alt=""
data:image/s3,"s3://crabby-images/ec12b/ec12b669f13e4ced0208d9efc9bf2c67578ad40d" alt=""
2.2 填写仓库地址
选择源码管理,然后填写gitlab仓库信息,但是我们发现报错了,因为jenkins没有拉取gitlab项目的权限。
data:image/s3,"s3://crabby-images/cdacd/cdacdc18677fadf15fcf5aa46d0fdba2df0420c8" alt=""
3.配置jenkins访问gitlab的权限
3.1 部署公钥解释和步骤
解释
1.如果我们想让jenkins从gitlab上拉取代码,那么需要将jenkins的公钥信息放在gitlab上。
2.gitlab针对这种情况有一个专门的功能,叫做部署部署公钥。
3.部署公钥的作用是不需要创建虚拟用户和组,直接在需要拉取的项目里关联部署公钥即可。
步骤
1.获取jenkins公钥信息
2.将jenkins公钥信息填写到gitlab的部署公钥里
3.由项目管理员操作,在需要jenkins拉取的项目里关联部署公钥
4.jenkins配置私钥凭证,部署项目时关联凭证
3.2 获取jenkins服务器的SSH公钥信息
[root@jenkins-201 ~]# cat .ssh/id_rsa.pub
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQCg8+DQFOjR+gl1Xw83CIyGJ50vI4DBeTaMRFdu5+5pT/IMnYq1iS7/lRS6JxXLYvVeNMDUfDxA1sOL70okyA3npjASXgJPGE1FsbpqzWjsN0TAGoZkR1VWuP9Yn0CrH7dA4lhZQfUUVjvqzFBZK8N9iZMzIu6KOiSY/aD4Ol59vbDS4kO0rTG1DYQNnjZzMPNlIiJ+0EVkfuYRwABRFA8fmL+6btqZqhjGY29EHuIfzIMTDTysrtCTGxQn2ql1zwjReGiNXzmFncwvyy92DAuMbnOQiE1YNn72wThy2oWSHsCwKdIvcNHqY2xBvFnkZ9Ltga7PgR33kbJ7Gl8tjiZF root@jenkins-201
3.3 gitlab添加部署公钥
data:image/s3,"s3://crabby-images/2dfbc/2dfbc517974b2619289d3ed2310bd8ab3ce6a3a8" alt=""
data:image/s3,"s3://crabby-images/acabd/acabd74fca12e24e1f7b7b5cb42ad73683efd381" alt=""
data:image/s3,"s3://crabby-images/cecbf/cecbfccf25de9d332550201c0d65a905ed262a3f" alt=""
3.4 gitlab项目关联部署公钥
data:image/s3,"s3://crabby-images/4e998/4e9981e80a334c99b7c65ca8ee249ca11ccff521" alt=""
data:image/s3,"s3://crabby-images/b550b/b550bf47bd8e0081801c9269d2fbc3e7459a9109" alt=""
data:image/s3,"s3://crabby-images/3cdbd/3cdbd65076ab26e06bb7afdfb2b248f85e5c01e9" alt=""
3.5 jenkins配置私钥凭证
data:image/s3,"s3://crabby-images/9d631/9d6312951237f8a168752db7d7073dd5e52c2d46" alt=""
data:image/s3,"s3://crabby-images/32588/325882560899ce7e0f1d5124188b368fceef4ed6" alt=""
data:image/s3,"s3://crabby-images/76671/76671804d61b3c3f52b3ee68c3ab1073d9a7aa5e" alt=""
3.6 测试获取代码
data:image/s3,"s3://crabby-images/08771/087717fa543418c1e62b9f11d21658812d41415f" alt=""
data:image/s3,"s3://crabby-images/19f32/19f3204119a6d0f97aa723a64bb7d263127db12e" alt=""
data:image/s3,"s3://crabby-images/4c6f3/4c6f3b3b717d68ba1c30aec207e8208c412b2d82" alt=""
查看拉取的代码:
[root@jenkins-201 ~]# ll /var/lib/jenkins/workspace/h5game
总用量 16
drwxr-xr-x 4 jenkins jenkins 47 8月 6 09:37 game
-rw-r--r-- 1 jenkins jenkins 9349 8月 6 09:37 LICENSE
-rw-r--r-- 1 jenkins jenkins 937 8月 6 09:37 README.md
4.编写部署脚本
#创建目录
mkdir -p /scripts/jenkins/
#编写脚本
cat > /scripts/jenkins/deploy.sh << 'EOF'
#!/bin/bash
PATH_CODE=/var/lib/jenkins/workspace/h5game/
PATH_WEB=/usr/share/nginx
TIME=$(date +%Y%m%d-%H%M)
IP=10.0.0.7
#打包代码
cd ${PATH_CODE}
tar zcf /opt/${TIME}-web.tar.gz ./*
#拷贝打包好的代码发送到web服务器代码目录
ssh ${IP} "mkdir ${PATH_WEB}/${TIME}-web -p"
scp /opt/${TIME}-web.tar.gz ${IP}:${PATH_WEB}/${TIME}-web
#web服务器解压代码
ssh ${IP} "cd ${PATH_WEB}/${TIME}-web && tar xf ${TIME}-web.tar.gz && rm -rf ${TIME}-web.tar.gz"
ssh ${IP} "cd ${PATH_WEB} && rm -rf html && ln -s ${TIME}-web html"
EOF
#添加可执行权限
chmod +x /scripts/jenkins/deploy.sh
也可以使用jenkins内置的变量来代替自定义变量,查看jenkins内置变量的地址如下:
http://10.0.0.201:8080/env-vars.html
4.jenkins调用构建脚本
在构建的位置填写执行shell脚本的命令
data:image/s3,"s3://crabby-images/bab36/bab36e06a030709c91c3a5a79941e6d30574e49d" alt=""
然后立即构建,发现报错了,提示权限不足:
data:image/s3,"s3://crabby-images/d9a83/d9a8349592c31fa8cbb6aae613fc7380f689ddc2" alt=""
报错原因是因为jenkins是以jenkins用户运行的,所以提示权限不足,我们可以修改jenkins为root用户运行。
[root@jenkins-201 ~]# vim /etc/sysconfig/jenkins
[root@jenkins-201 ~]# grep "USER" /etc/sysconfig/jenkins
JENKINS_USER="root"
[root@jenkins-201 ~]# systemctl restart jenkins
重启好之后我们重新构建一下:
data:image/s3,"s3://crabby-images/daef1/daef1fca23c25c5965d42600d3bba280eb652c22" alt=""
查看一下web服务器的代码目录
[root@web-7 ~]# ll /usr/share/nginx/
总用量 0
drwxr-xr-x 3 root root 50 8月 6 10:13 20200806-1013-web
lrwxrwxrwx 1 root root 17 8月 6 10:13 html -> 20200806-1013-web
第4章 监听gitlab自动触发构建
1.jenkins项目里添加构建触发器
data:image/s3,"s3://crabby-images/e2438/e2438aed2d011910846e8f14d36eb90d16cbaebd" alt=""
2.gitlab添加webhook
将刚才jenkins里配置的token和URL地址复制进去
data:image/s3,"s3://crabby-images/13f1c/13f1c18ec5c81f601337913e1b59c2329c1edbb3" alt=""
较新版本的gitlab此时点击添加会提示报错:
data:image/s3,"s3://crabby-images/38dfc/38dfcdf295519377b3398351228168b69b2bb309" alt=""
解决方法:进入admin area区域,然后点击setting-->network进行设置
data:image/s3,"s3://crabby-images/b4814/b48142a9574ecc2119ee79ea31a268dae063b26a" alt=""
正常添加成功之后,会在下方出现测试的选项
data:image/s3,"s3://crabby-images/3662b/3662b3e6cd2fe5509bb23543a82172fd334b2b3b" alt=""
选择push事件来测试是否可以正常出发,如果可以,会在页面上方显示200状态码
data:image/s3,"s3://crabby-images/8e68d/8e68d17a435b90deedb8f5f9005f7e517ab839ea" alt=""
此时我们去查看jenkins项目页面,就会发现以及出发了来自gitlab的构建任务
data:image/s3,"s3://crabby-images/afefe/afefe448e337e3ef564bb83fc15a9187a5712549" alt=""
第5章 返回构建状态给gitlab
1.gitlab生成access token
data:image/s3,"s3://crabby-images/55785/557858f169f5abe82d0e2a938196cb1f9d222827" alt=""
点击创建之后会生成一串token,注意及时保存,因为刷新就没有了
data:image/s3,"s3://crabby-images/eb3ee/eb3eea9a66770bc0bcdc9daa55d982d23c155ba2" alt=""
2.jenkins配置gitlab的token
点击jenkins的系统管理-->系统设置,然后找到gitlab选项
data:image/s3,"s3://crabby-images/db1e5/db1e5330e827dfe5b14f059f29f19d56868f16ad" alt=""
填写gitlab的信息:
data:image/s3,"s3://crabby-images/f1cd2/f1cd25dfb9ca5d384c65333d7de3273df9813b4b" alt=""
点击添加后返回上一层页面,然后选中刚才添加的gitlab凭证
data:image/s3,"s3://crabby-images/bdcf0/bdcf0b000cd6ad5e01c6f49e4e6ba47f9197149e" alt=""
3.设置项目构建后将结果通知给gitlab
data:image/s3,"s3://crabby-images/bf7cb/bf7cba5fdc48b529373f1175db90d83964ed2479" alt=""
4.合并分支然后检查gitlab能否收到消息
data:image/s3,"s3://crabby-images/f091b/f091b672cd65b0809af0a4fdf10ce445e6ea01f7" alt=""
5.防止重复构建
jenkins具有很多内置变量,点击项目-->构建--> 查看 可用的环境变量列表
http://10.0.0.201:8080/env-vars.html/
这里我们使用两个变量,一个是此次提交的commit的hash,另一个是上一次提交成功的commit的hash
我们可以在部署脚本里添加一行判断,如果这两个变量一样,那么就不用再次提交了
这些变量不需要在脚本里定义,直接引用即可
data:image/s3,"s3://crabby-images/5315e/5315e433593168f5944bb5cf225f7ba381622b56" alt=""
第6章 tag方式发布版本
1.给代码打标签
首先我们先给代码打上标签,然后提交2个版本
v1.0版本:修改代码,然后发布v1.0版本
git commit -am 'v1.0'
git tag -a v1.0 -m "v1.0 稳定版"
git push -u origin v1.0
git tag
v2.0版本:修改代码,然后发布v2.0版本
git commit -am 'v2.0'
git tag -a v2.0 -m "v2.0 稳定版"
git push -u origin v2.0
git tag
2.gitlab查看标签
此时gitlab上可以看到2个标签
data:image/s3,"s3://crabby-images/14945/149453f38d4d8b57e822016b91a9db80c1e1ea81" alt=""
点进去之后可以看到具体标签名称
data:image/s3,"s3://crabby-images/b2515/b2515cb31536a2995100410cece20ee7f5157bac" alt=""
3.jenkins配置参数化构建
jenkins上我们新建一个参数化构建项目
data:image/s3,"s3://crabby-images/a0f0c/a0f0c5c15fce1d15c21c14368261560d8799be47" alt=""
然后配置git的标签参数:
data:image/s3,"s3://crabby-images/7d497/7d497b21d9108e1e3092aeaf07a0bab4c6eabe35" alt=""
最后还需要配置一下git仓库地址,注意需要修改拉取的版本的变量为 $git_version
data:image/s3,"s3://crabby-images/f2286/f22868ca3b13df98f92bcc5af54e499f77b413ea" alt=""
此时点击项目的build with parameters就会看到对应的版本号:
data:image/s3,"s3://crabby-images/ffca9/ffca979bb94ae136fb2181977a84537d8b23dcd4" alt=""
然后去jenkins工作目录下查看是否拉取了对应版本:
/var/lib/jenkins/workspace/my-deploy-rollback
4.优化部署脚本
cat >/scripts/jenkins/deploy_rollback.sh<<'EOF'
#!/bin/bash
PATH_CODE=/var/lib/jenkins/workspace/my-deploy-rollback/
PATH_WEB=/usr/share/nginx
IP=10.0.0.7
#打包代码
cd ${PATH_CODE}
tar zcf /opt/web-${git_version}.tar.gz ./*
#拷贝打包好的代码发送到web服务器代码目录
ssh ${IP} "mkdir ${PATH_WEB}/web-${git_version} -p"
scp /opt/web-${git_version}.tar.gz ${IP}:${PATH_WEB}/web-${git_version}
#web服务器解压代码
ssh ${IP} "cd ${PATH_WEB}/web-${git_version} && tar xf web-${git_version}.tar.gz && rm -rf web-${git_version}.tar.gz"
ssh ${IP} "cd ${PATH_WEB} && rm -rf html && ln -s web-${git_version} html"
EOF
5.jenkins添加执行脚本动作并测试
data:image/s3,"s3://crabby-images/919ff/919ffac785cb24070c9dc0554f3c8e0be79d697a" alt=""
6.测试发布
data:image/s3,"s3://crabby-images/2c13a/2c13afa1645fa98b39f71eecd070c8fd603dce8c" alt=""
然后去web服务器上查看发现已经发布了
[root@web-7 ~]# ll /usr/share/nginx/
总用量 0
lrwxrwxrwx 1 root root 8 8月 6 15:59 html -> web-v2.0
drwxr-xr-x 3 root root 68 8月 6 15:59 web-v2.0
第7章 tag方式回滚版本
1.jenkins配置回滚选项参数
在工程配置里添加选项参数:
data:image/s3,"s3://crabby-images/c310f/c310f312485af6a1167ae63ef3ca3082b920e2eb" alt=""
在参数化构建里添加2个选项:发布和回滚
data:image/s3,"s3://crabby-images/a9f15/a9f15b5c0a40da712e56de797b12c818c69b1c24" alt=""
此时查看构建页面就会发现多了选项卡:
data:image/s3,"s3://crabby-images/bef80/bef800147fed7aee3aa2e131846c511d2ca83a9c" alt=""
2.修改发布脚本增加条件判断
cat >/scripts/jenkins/deploy_rollback.sh <<'EOF'
#!/bin/bash
PATH_CODE=/var/lib/jenkins/workspace/my-deploy-rollback/
PATH_WEB=/usr/share/nginx
IP=10.0.0.7
#打包代码
code_tar(){
cd ${PATH_CODE}
tar zcf /opt/web-${git_version}.tar.gz ./*
}
#拷贝打包好的代码发送到web服务器代码目录
code_scp(){
ssh ${IP} "mkdir ${PATH_WEB}/web-${git_version} -p"
scp /opt/web-${git_version}.tar.gz ${IP}:${PATH_WEB}/web-${git_version}
}
#web服务器解压代码
code_xf(){
ssh ${IP} "cd ${PATH_WEB}/web-${git_version} && tar xf web-${git_version}.tar.gz && rm -rf web-${git_version}.tar.gz"
}
#创建代码软链接
code_ln(){
ssh ${IP} "cd ${PATH_WEB} && rm -rf html && ln -s web-${git_version} html"
}
main(){
code_tar
code_scp
code_xf
code_ln
}
#选择发布还是回滚
if [ "${deploy_env}" == "deploy" ]
then
ssh ${IP} "ls ${PATH_WEB}/web-${git_version}" >/dev/null 2>&1
if [ $? == 0 -a ${GIT_COMMIT} == ${GIT_PREVIOUS_SUCCESSFUL_COMMIT} ]
then
echo "web-${git_version} 已部署,不允许重复构建"
exit
else
main
fi
elif [ "${deploy_env}" == "rollback" ]
then
code_ln
fi
EOF
3.测试回滚功能
部署v1.0版本
data:image/s3,"s3://crabby-images/eee2e/eee2eeada4ed82230e66fce07700eb16fb45d17c" alt=""
部署v2.0版本:
data:image/s3,"s3://crabby-images/54f27/54f27267cafe9752c04c79a560e1b90e15e930a6" alt=""
检查web服务器当前的版本
[root@web-7 ~]# ll /usr/share/nginx/
总用量 0
lrwxrwxrwx 1 root root 8 8月 6 16:52 html -> web-v2.0
drwxr-xr-x 3 root root 68 8月 6 16:51 web-v1.0
drwxr-xr-x 3 root root 68 8月 6 16:52 web-v2.0
然后我们选择v1.0版本并且选择回滚操作:
data:image/s3,"s3://crabby-images/54f08/54f08e99130b43cede8b6731092aade243cea964" alt=""
查看控制台显示回滚成功:
data:image/s3,"s3://crabby-images/9abc4/9abc49797c215193e9d0593906beaeb4533dc2b3" alt=""
在web服务器上查看发现已经回滚成功:
[root@web-7 ~]# ll /usr/share/nginx/
总用量 0
lrwxrwxrwx 1 root root 8 8月 6 16:56 html -> web-v1.0
drwxr-xr-x 3 root root 68 8月 6 16:51 web-v1.0
drwxr-xr-x 3 root root 68 8月 6 16:52 web-v2.0
4.发布新代码并打标签测试
修改代码并发布v3.0:
cd h5game/
echo v3.0 >> index.html
git commit -am 'v3.0'
git tag -a v3.0 -m 'v3.0 稳定版'
git push -u origin v3.0
git tag
jenkins查看并发布3.0版本:
[图片上传失败...(image-a1e6e7-1598955937011)]
web服务器查看发布情况:
[root@web-7 ~]# ll /usr/share/nginx/
总用量 0
lrwxrwxrwx 1 root root 8 8月 6 16:58 html -> web-v3.0
drwxr-xr-x 3 root root 68 8月 6 16:51 web-v1.0
drwxr-xr-x 3 root root 68 8月 6 16:52 web-v2.0
drwxr-xr-x 3 root root 68 8月 6 16:58 web-v3.0
然后工程选择回滚到v2.0版本:
data:image/s3,"s3://crabby-images/7a74b/7a74b4f019f801d1beb1f5a368dc53979bc04b9a" alt=""
再次在web服务器上查看:
[root@web-7 ~]# ll /usr/share/nginx/
总用量 0
lrwxrwxrwx 1 root root 8 8月 6 16:59 html -> web-v2.0
drwxr-xr-x 3 root root 68 8月 6 16:51 web-v1.0
drwxr-xr-x 3 root root 68 8月 6 16:52 web-v2.0
drwxr-xr-x 3 root root 68 8月 6 16:58 web-v3.0
第8章 打标签工程
1.jenkins新建打标签工程
data:image/s3,"s3://crabby-images/9cfa6/9cfa64dd7420538bd1ee94e212a7acb7d383f6a1" alt=""
2.配置参数化构建
data:image/s3,"s3://crabby-images/947d0/947d0e066348b1afabc0146d84c0d1235bd21263" alt=""
3.配置工程的源码管理
data:image/s3,"s3://crabby-images/e5d42/e5d424170a9bf522630159520ce2e016dec53519" alt=""
4.配置构建动作
data:image/s3,"s3://crabby-images/8b413/8b413a5fd1f1f0e87bdb03fdc4b82f4176a60bc9" alt=""
配置命令:
git tag -a $git_newversion -m "$git_newversion 稳定版"
git push -u origin $git_newversion
5.发布新版本并提交到master
echo "v4.0" >> index.html
git add .
git commit -m "v4.0 稳定版"
git push -u origin v4.0
6.jenkins使用打标签工程来打标签
data:image/s3,"s3://crabby-images/e47ab/e47ab0ccad58d966e77e7fc42f45a9f0f9c6c6aa" alt=""
查看控制台输出发现提示没有权限:
data:image/s3,"s3://crabby-images/6758f/6758f7fe935d4c381fa3c8406f3cbe20c69fa178" alt=""
我们需要在gitlab上把deploy key设置允许写入
data:image/s3,"s3://crabby-images/92d5b/92d5b370e47ad9f704c81dd20443e79be0a0ef0d" alt=""
data:image/s3,"s3://crabby-images/e84ac/e84ac333f224335f1125ef985f5bda94f454acb8" alt=""
然后重新构建
返回到deploy-rollback工程查看可以发现已经生成了新标签,然后我们开始构建:
data:image/s3,"s3://crabby-images/a0647/a06478bd29908188dd79b305ff831a2fd1567303" alt=""
在web服务器上查看可以发现新版本已经发布成功了:
[root@web ~]# ll /usr/share/nginx/
总用量 20
lrwxrwxrwx 1 root root 8 5月 13 16:09 html -> web-v4.0
drwxr-xr-x 8 root root 4096 5月 13 16:05 web-
drwxr-xr-x 8 root root 4096 5月 13 15:00 web-v1.0
drwxr-xr-x 8 root root 4096 5月 13 15:00 web-v2.0
drwxr-xr-x 8 root root 4096 5月 13 15:37 web-v3.0
drwxr-xr-x 8 root root 4096 5月 13 16:09 web-v4.0
</article>
2人点赞
网友评论