本文环境
Docker Version 19.03.11:https://www.cnblogs.com/niceyoo/p/13096181.html
Maven Version 3.3.9:https://www.cnblogs.com/niceyoo/p/13068935.html
JDK Version 1.8.0_181:https://www.cnblogs.com/niceyoo/p/11483139.html
GitLab:https://www.cnblogs.com/niceyoo/p/13057533.html
Jenkins Version 2.222.4:参考本文
通过本文可以了解哪些
通过Docker部署Jenkins
使用Jenkins一键部署Springboot项目
整合GitLab实现上传代码自动部署项目
如下Jenkins安装及配置过程
1、拉取代码
docker pull jenkins/jenkins:lts
2、创建并启动容器:
在构建的过程,由于我本身CentOS已经安装JDK、Maven了「可以参考上方的安装链接」,所以在这我就直接指定本地环境变量了,当然,如果你不指定的话,安装完Jenkins后还是可以在全局工具配置中修改的:
docker run --name=jenkins --privileged=true
-u root
–rm
-d
-p 8080:8080
-p 50000:50000
-v /var/run/docker.sock:/var/run/docker.sock
-v /usr/bin/docker:/usr/bin/docker
-v $(which docker):/usr/bin/docker
-v /etc/sysconfig/docker:/etc/sysconfig/docker
-v /usr/java/jdk1.8.0_181:/usr/java/jdk1.8.0_181
-v /home/maven/apache-maven-3.3.9:/usr/local/maven
-v /home/maven/repo:/usr/local/maven_repository
-v /home/jenkins-data:/var/jenkins_home
jenkins/jenkins:lts
启动后在浏览器输入:http://容器ip:8080 访问。
管理员密码需要我们在log中查询:
docker logs jenkins
3、安装推荐的插件
输入密码登陆后,会弹出插件安装提示,我们在这选择安装推荐的插件:
4、创建管理员账号
安装之后,接下来创建一个账号:
进行实例地址配置,该地址将作为将来Jenkins的访问地址:
至此,保存并完成,会重启Jenkins,然后我们可以通过刚刚创建的账户登录「使用管理员root也可以」:
5、Maven配置修改
之前我们创建容器时复用了本地宿主机的Maven环境变量,但是安装完Jenkins后还是要指定一下Maven目录的,依次进入:系统管理 > 全局工具配置
首先是顶部的Maven,我们选择文件系统中的setting文件,文件路径使用创建容器时指定的Maven路径 usr/local/maven:
/usr/local/maven/conf/settings.xml
然后拉到最下边Maven节点,点击新增Maven,起一个名字,然后指定maven路径,去掉自动安装的选项,然后应用>保存:
6、新建一个任务
点击确定之后会跳入配置界面,接下来就是配置我们的自动化操作,首先是配置项目的拉取地址,在这我是基于Gitlab的,关于Gitlab的搭建可以参考这篇:https://www.cnblogs.com/niceyoo/p/13057533.html
点击添加GitLab的账户密码,不添加时会报红,是没法在GitLab中拉取代码的:
#!/bin/bash
result=result" != “” ]]
then
echo “stop niceyoo-demo”
docker stop niceyoo-demo
fi
result1=result1" != “” ]]
then
echo “rm niceyoo-demo”
docker rm niceyoo-demo
fi
result2=result2" != “” ]]
then
echo “10.211.55.4:5000/niceyoo-demo:latest”
docker rmi 10.211.55.4:5000/niceyoo-demo:latest
fi
个地方解释一下为啥要用到shel脚本,这个脚本有两个操作,首先是通过 docker ps | grep "10.211.55.4:5000/niceyoo-demo"查询是否存在容器,如果存在的话则stop停止容器,然后再rm删除容器,第二步是通过 docker ps -a | grep "10.211.55.4:5000/niceyoo-demo"查看是否存在该镜像,如果存在则 rmi 删除该镜像,为啥要删除镜像+容器?其实这样是帮助我们把每次自动化构建镜像、容器之前都把旧的给删除掉。
“10.211.55.4:5000/niceyoo-demo” 是我项目打包后的镜像名称,组成规则为:镜像地址/项目名称
然后添加Maven指令,用于构建项目,简单说一下这个地方,我在项目的 pom.xml,文件中使用了 docker-maven-plugin 插件,同时替换了 mvn pavkage 指令,当每次执行该命令时就会自动提交至Docker远程私有仓库中,「如果在本地执行测试的话需要开启Docker远程访问前提,具体配置可参考该链接:https://www.cnblogs.com/niceyoo/p/13270224.html」,私有仓库是基于Docker+Registry搭建的,关于Registry的搭建可以参考这篇:https://www.cnblogs.com/niceyoo/p/13058238.html
clean package
如下是SpringBoot项目 pom.xml 文件中的插件编写,已经把注释写的很清楚了:
build>
org.springframework.boot
spring-boot-maven-plugin
com.spotify
docker-maven-plugin
1.0.0
10.211.55.4:5000/{project.basedir}/src/main/resources–>
latest
10.211.55.4:5000
true
java
niceyoo [email protected]
/ROOT
[“java”,"-version"]
[“java”,"-jar","{project.build.directory}表示target目录–>
{project.build.finalName}.jar表示打包后的jar包文件–>
${project.build.finalName}.jar
build-image
package
build
docker run --rm -d -p 9999:9999 --name niceyoo-demo 10.211.55.4:5000/niceyoo-demo
部分参数解释:在这我用的 -p 9999 端口,–nama 后面指向的是重命名后的容器名称 niceyoo-demo + 镜像的名称 10.211.55.4:5000/niceyoo-demo,接下来就是应用+保存了: