平时上线的你可能是重复着以下步骤:
①提交代码→②本地打包→③将应用上传到服务器并启动
假如线上有一个bug,你可能需要再一次历经上面三个步骤才算真正解决掉这个bug。
有了Jenkins和Docker两大法宝后,你上线的步骤变为:
①提交代码→②登录Jenkins启动任务(新建任务在第一次上线时完成)
对比上面的步骤少了一个步骤。Jenkins和Docker帮助我们解决了什么问题呢?不用再手动打包了,这是因为可以在Jenkins网页配置Maven打包命令。不用再手动输入命令启动应用了,这是因为Jenkins支持远程SSH工具,SSH工具就是通过脚本来执行远程应用的利器。
1、Docker的安装及配置
可自行搜索安装。
2、Jenkins的安装及配置
2.1、拉取Jenkins的Docker镜像
docker pull jenkins/jenkins:lts
lts表示官方最新且稳定的版本,大小为701M。
2.2、预先解决插件下载龟速问题
2.2.1、查看jenkins版本号
cat /mydata/jenkins_home/config.xml
版本号位于第四行的version标签内,这里的版本号为2.263.1。为啥要查一下版本号呢?根据笔者的经验,随着版本的升级,镜像源对应的初始配置内容也会发生变化,所以旧版本被修改的内容可能已经不适用了。
2.2.2、default.json文件中针对部分内容进行替换
执行命令:
sed -i 's/www.google.com/www.baidu.com/g' /mydata/jenkins_home/updates/default.json
sed -i 's/https:\/\/updates.jenkins.io\/download/https:\/\/mirrors.tuna.tsinghua.edu.cn\/jenkins/g' /mydata/jenkins_home/updates/default.json
注:第二行需要修改的内容可能会随着Jenkins的版本升级发生变化,一般情况下,找到updates开头的二级域名即可。
2.3、在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
命令详解:
第一行:
-p:表示【指定】端口映射,格式为主机(容器)端口:容器端口,启动时以冒号左边的端口号为准。这条命令包含两个端口映射:
8080是访问Jenkins网页的端口号,如果想通过其他端口号来访问Jenkins,通过更改命令中的端口号来启动是行不通的;
50000端口号的由来:Jenkins实际上是使用JNLP语言来建设服务器的,而JNLP所需的服务端口正是50000;
--name 容器名称:指定启动时的容器的名称,通过自定义的命名方式能便于快速地发现容器的位置,这里的容器名称是jenkis;
第二行:
-u root:指定用户名为root的用户来启动Jenkins;
第三行:
-v /mydata/jenkins_home:/var/jenkins_home:挂载了宿主机的一个指定目录到/var/jenkins_home,相当于设置了自定义的JENKINS_HOME;
第四行:
-d jenkins/jenkins:lts:后台运行容器,jenkins/jenkins:lts为拉取时的镜像名称。
2.4、进入Jenkins网页
2.4.1、获取管理员密码
方法1:Windows-IDEA的Docker控制台
方法2:Linux-启动日志
docker logs jenkins
2.4.2、解锁Jenkins
输入网址:服务器IP地址:8080,使用上一步获取的管理员密码来解锁。
2.4.3、安装推荐的插件
2.4.4、等待插件安装完成,创建管理员账号
2.4.5、实例配置
2.4.6、必备插件安装
点击Manage Jenkins→Manage Plugins进入到插件管理界面
-
SSH安装,用于配置远程站点的参数
等待安装完成后,点击返回首页→Manage Jenkins→Manage Plugins继续安装。
-
Role-based Authorization Strategy安装,支持根据角色管理权限。
2.4.7、全局Maven配置
点击Manage Jenkins-Global Tool Configuration,新增Maven配置
2.4.8、全局SSH配置
-
添加凭据
点击首页→Manage Jenkins→Manage Credentials→添加凭据
输入信息保存凭据
-
SSH远程主机配置
2.4.9、角色权限配置
-
全局安全配置
Jenkins的角色管理插件可以帮助我们管理Jenkins的用户,对于不同的角色可以给到其应有的权限。
点击首页→Manage Jenkins→Configure Global Security
-
管理和分配角色
点击首页→Manage Jenkins
3、SpringBoot应用的打包并部署
3.1、代码上传到Git仓库
Git仓库没有指定厂商,可以是Gitlab、GitHub和Gitee其中的一个。
3.2、打包前准备
- 配置检查
这里的打包是通过docker构建应用的镜像并上传到docker容器内,需要在pom.xml中进行配置,打开pom.xml,定位到<plugins>标签下,补充docker插件的配置内容:
<plugin>
<groupId>com.spotify</groupId>
<artifactId>docker-maven-plugin</artifactId>
<version>1.1.0</version>
<executions>
<execution>
<id>build-image</id>
<phase>package</phase>
<goals>
<goal>build</goal>
</goals>
</execution>
</executions>
<configuration>
<imageName>${project.artifactId}:${project.version}</imageName>
<dockerHost>http://192.168.1.41:2375</dockerHost>
<baseImage>anapsix/alpine-java:8_server-jre_unlimited</baseImage>
<entryPoint>["java", "-jar", "/${project.build.finalName}.jar"]
</entryPoint>
<resources>
<resource>
<targetPath>/</targetPath>
<directory>${project.build.directory}</directory>
<include>${project.build.finalName}.jar</include>
</resource>
</resources>
</configuration>
</plugin>
<dockerHost>标签的内容需要替换成自己的Docker镜像仓库地址,注意生产环境切勿随意开启2375端口,可以通过在云服务内指定连接IP的方式开启2375端口。
<baseImage>标签中内容是JDK环境,anapsix/alpine-java:8_server-jre_unlimited的优点在于打包后的镜像体积小,一般在一两百兆左右,节省了大量的硬盘空间。
- 编写执行脚本
mkdir /mydata/sh
cd /mydata/sh
echo '#!/usr/bin/env bash' > start.sh
echo "app_name='应用名称'" >> start.sh
echo "docker stop ${app_name}" >> start.sh
echo "echo '----stop container----'" >> start.sh
echo "docker rm ${app_name}" >> start.sh
echo "echo '----rm container----'" >> start.sh
echo "docker run --name ${app_name} -d -p 主机(容器)端口:容器端口 -v /mydata/app/${app_name}/logs:/home/workspace/app/logback ${app_name}:0.0.1-SNAPSHOT" >> start.sh
echo "echo '----start container----'" >> start.sh
- 给执行脚本添加可执行权限
chmod +x ./mall-tiny-jenkins.sh
3.3、在Jenkins中新建任务
3.3.1、新建一个任务
点击首页→新建任务
3.3.2、添加Git仓库地址
3.3.3、添加Maven构建
3.3.4、添加远程执行脚本构建
command项输入脚本执行命令:/mydata/sh/start.sh
点击保存后就可以在任务列表中看到新创建的任务了,点击最后一个图标运行任务,点击控制台输出可查看打印内容。