![d8a8379af1840a0aa4e0e71c0c3ceb94.png](https://i-blog.csdnimg.cn/blog_migrate/6e4c297ab85bb551bdc0f090e1e819aa.jpeg)
摘要
任何简单操作的背后,都有一套相当复杂的机制。本文将以SpringBoot应用的在Docker环境下的打包部署为例,详细讲解如何使用Jenkins一键打包部署SpringBoot应用。
Jenkins简介
Jenkins是开源CI&CD软件领导者,提供超过1000个插件来支持构建、部署、自动化,满足任何项目的需要。我们可以用Jenkins来构建和部署我们的项目,比如说从我们的代码仓库获取代码,然后将我们的代码打包成可执行的文件,之后通过远程的ssh工具执行脚本来运行我们的项目。
Jenkins的安装及配置
Docker环境下的安装
- 下载Jenkins的Docker镜像:
docker pull jenkins/jenkins:lts
- 在Docker容器中运行Jenkins:
docker run -p 8080:8080 -p 50000:5000 --name jenkins -u root -v /mydata/jenkins_home:/var/jenkins_home -d jenkins/jenkins:lts
Jenkins的配置
- 运行成功后访问该地址登录Jenkins,第一次登录需要输入管理员密码:http://192.168.6.132:8080/
![e05b500b4f7548f650ba86bbad546c7b.png](https://i-blog.csdnimg.cn/blog_migrate/426f3be15a3b5e69a76d6a01f72cd3de.png)
- 使用管理员密码进行登录,可以使用以下命令从容器启动日志中获取管理密码:
docker logs jenkins
- 从日志中获取管理员密码:
![13d2ab41cc28d9cafe3bbe44870f3b68.png](https://i-blog.csdnimg.cn/blog_migrate/b56d766491ae7f73396986f5b290c5be.jpeg)
- 选择安装插件方式,这里我们直接安装推荐的插件:
![6c173cb89829d2df3d8d36465a14facc.png](https://i-blog.csdnimg.cn/blog_migrate/a044bd54ab3771470d51f2a58b1d8750.png)
- 进入插件安装界面,联网等待插件安装:
![9dab136429a0cee360ff612aa66f380f.png](https://i-blog.csdnimg.cn/blog_migrate/64ad734076bb6db082ff03b91d97edfb.png)
- 安装完成后,创建管理员账号:
![2b7a6e042c5856a8b40b60cb70cec176.png](https://i-blog.csdnimg.cn/blog_migrate/0fdd37494e835c775f1529501c33d981.png)
- 进行实例配置,配置Jenkins的URL:
![b1452ac2ea09fa9aaf21784d3a8f1d87.png](https://i-blog.csdnimg.cn/blog_migrate/d6c3e71670fd293401195d87beaee3fb.png)
- 点击系统管理->插件管理,进行一些自定义的插件安装:
![33f8fe3dd8c810e06accfb00f81d656a.png](https://i-blog.csdnimg.cn/blog_migrate/05439c72829dc885a16abbe56349a701.png)
- 确保以下插件被正确安装:
- 根据角色管理权限的插件:Role-based Authorization Strategy
- 远程使用ssh的插件:SSH plugin
- 通过系统管理->全局工具配置来进行全局工具的配置,比如maven的配置:
![78d11a0c971c2686496d6b637b2dcb16.png](https://i-blog.csdnimg.cn/blog_migrate/1b1a28ad61fbd4930b5895f58a33bcc2.png)
- 新增maven的安装配置:
![efca9e18d2c555332690fb5abc328559.png](https://i-blog.csdnimg.cn/blog_migrate/312fc27297b7108b6a43d7e9f68c2b89.png)
- 在系统管理->系统配置中添加全局ssh的配置,这样Jenkins使用ssh就可以执行远程的linux脚本了:
![6b43a56f080e57fb84bdd0a543df4488.png](https://i-blog.csdnimg.cn/blog_migrate/8919c23402cdc1560b394816ea9a674d.png)
角色权限管理
我们可以使用Jenkins的角色管理插件来管理Jenkins的用户,比如我们可以给管理员赋予所有权限,运维人员赋予执行任务的相关权限,其他人员只赋予查看权限。
- 在系统管理->全局安全配置中启用基于角色的权限管理:
![6e74a4a96b79d327ac6d13d731abacc3.png](https://i-blog.csdnimg.cn/blog_migrate/0eb807aa31a93b46b6daca745dfb18df.jpeg)
- 进入系统管理->Manage and Assign Roles界面:
![14064c224b1d9e6dc525011ee3574268.png](https://i-blog.csdnimg.cn/blog_migrate/b29efdd183166f41b7df1066d16fc13c.jpeg)
- 添加角色与权限的关系:
![7180d15704b270cc9b14e56ad175aa02.png](https://i-blog.csdnimg.cn/blog_migrate/01140cadc9d0a826c636d4f2e0941fd1.jpeg)
- 给用户分配角色:
![3b916c99176a6032973145aef36ff5bc.png](https://i-blog.csdnimg.cn/blog_migrate/6ffd483847762a39bd050f80b0b06b1b.png)
打包部署SpringBoot应用
这里我们使用mall-learning
项目中的mall-tiny-jenkins
模块代码来演示下如何使Jenkins一键打包部署SpringBoot应用。
将代码上传到Git仓库
- 首先我们需要安装Gitlab(当然你也可以使用Github或者Gitee),然后将
mall-tiny-jenkins
中的代码上传到Gitlab中去,Gitlab的使用请参考:10分钟搭建自己的Git仓库 mall-tiny-jenkins
项目源码地址:github.com/macrozheng/…- 上传完成后Gitlab中的展示效果如下:
![cce03ba071056845725c0b8a68ad6ccc.png](https://i-blog.csdnimg.cn/blog_migrate/39616fad04d0b9689afb3dcc5f789ca1.jpeg)
- 有一点需要
注意
,要将pom.xml中的dockerHost地址改成你自己的Docker镜像仓库地址:
![d882ff2e2c86e2e8cda3a16140c3284f.png](https://i-blog.csdnimg.cn/blog_migrate/afcb069410d1ffeb5a18cd33eec93137.jpeg)
执行脚本准备
- 将
mall-tiny-jenkins.sh
脚本文件上传到/mydata/sh
目录下,脚本内容如下:
#!/usr/bin/env bash app_name='mall-tiny-jenkins' docker stop ${app_name} echo '----stop container----' docker rm ${app_name} echo '----rm container----' docker run -p 8088:8088 --name ${app_name} --link mysql:db -v /etc/localtime:/etc/localtime -v /mydata/app/${app_name}/logs:/var/logs -d mall-tiny/${app_name}:1.0-SNAPSHOT echo '----start container----'
- 给.sh脚本添加可执行权限:
chmod +x ./mall-tiny-jenkins.sh
- windows下的.sh脚本上传到linux上使用,需要修改文件格式,否则会因为有特殊格式存在而无法执行:
#使用vim编辑器来修改 vi mall-tiny-jenkins.sh # 查看文件格式,windows上传上来的默认为dos :set ff #修改文件格式为unix :set ff=unix #保存并退出 :wq
- 执行.sh脚本,测试使用,可以不执行:
./mall-tiny-jenkins.sh
在Jenkins中创建执行任务
- 首先我们需要新建一个任务:
![17648e12785ab61741201cab06758971.png](https://i-blog.csdnimg.cn/blog_migrate/661116af440edb828b62cd5f25adedd6.jpeg)
- 设置任务名称后选择构建一个自由风格的软件项目:
![44e6f231300218a3b4d3be0a66ea59c4.png](https://i-blog.csdnimg.cn/blog_migrate/d46dbf9a5571b73fbd5e64db8488e128.jpeg)
- 然后在源码管理中添加我们的git仓库地址:http://192.168.6.132:1080/macrozheng/mall-tiny-jenkins
![c49e4efbc7173a216eccbd72aa87b176.png](https://i-blog.csdnimg.cn/blog_migrate/05235a1b1dad33fc7b06b785feeb93d1.jpeg)
- 此时需要添加一个凭据,也就是我们git仓库的账号密码:
![13d95e44806cb715b0ff3ca69608f955.png](https://i-blog.csdnimg.cn/blog_migrate/1a47665e652ef4135016cd5899cfd47d.jpeg)
- 填写完成后选择该凭据,就可以正常连接git仓库了;
![f4951f51c3af69b7aaf6799ef1137b24.png](https://i-blog.csdnimg.cn/blog_migrate/ee7b5a811cb44f3234c94842800a0e94.jpeg)
- 之后我们需要添加一个构建,选择调用顶层maven目标,该构建主要用于把我们的源码打包成Docker镜像并上传到我们的Docker镜像仓库去:
![ad3bb947ff7774bf81d14d460b576d51.png](https://i-blog.csdnimg.cn/blog_migrate/f38213bc429e39e63f9c8c3b0a34af79.jpeg)
- 选择我们的maven版本,然后设置maven命令和指定pom文件位置:
![3e54f3971dd7fa45cdec280686d98e5a.png](https://i-blog.csdnimg.cn/blog_migrate/c8f0e657351720e61b1289c85e41e72e.jpeg)
- 之后添加一个执行远程shell脚本的构建,用于在我们的镜像打包完成后执行启动Docker容器的.sh脚本:
![368a74fbff8c116cce1c5f888f1e6160.png](https://i-blog.csdnimg.cn/blog_migrate/a1db7dd5cb25664b85b6dd7089e67771.jpeg)
- 需要设置执行的shell命令如下:/mydata/sh/mall-tiny-jenkins.sh
![5b3e3f6c3b2e38392eda5667fb68cc90.png](https://i-blog.csdnimg.cn/blog_migrate/203501aab5e2370b0e461167fbc48ab9.jpeg)
- 之后点击保存操作,我们的任务就创建完成了,在任务列表中我们可以点击运行来执行该任务;
![37659ecfba1e792735dd0e69153fe81b.png](https://i-blog.csdnimg.cn/blog_migrate/214b48b31ee076c69c555bfee4da1180.jpeg)
- 我们可以通过控制台输出来查看整个任务的执行过程:
![d04a5a29eb8d5818c428df393cd8b982.png](https://i-blog.csdnimg.cn/blog_migrate/82c3ee142ccd21e924b79ca3dffec3c9.jpeg)
- 运行成功后,访问该地址即可查看API文档:[http://192.168.6.132:8088/swagger-ui.html]
![b87782113e1414fb9be9d674baac0982.png](https://i-blog.csdnimg.cn/blog_migrate/b7ed74dfecb847104dbf331883e218b7.jpeg)
作者:MacroZheng
原文链接:https://juejin.im/post/5df780d3e51d4557ff140b30