jenkins简介
Jenkins是一个开源软件项目,是基于Java开发的一种持续集成工具,用于监控持续重复的工作,旨在提供一个开放易用的软件平台,使软件项目可以进行持续集成。
为什么使用?
开发人员在开发的过程中,会把代码提交到git远程仓库,然后需要通过拉取、编译、打包、部署等操作让测试人员在测试服务器上测试功能。 每次提交到git仓库都需要重复做这样的拉取、编译、打包、部署操作,非常的耗时。 然而持续集成工具jenkins,可以帮助开发人员完成这些工作。
安装jenkins
jenkins是使用java语言编写的一款工具。必须在虚拟机或服务器安装JDK配置环境变量。
(前面的文章有讲过怎么安装jdk 这里的jdk必须为11 、17、21版本)
(1)把jenkins.war上传到虚拟机指定目录下
(2)安装配置文件 yum install fontconfig
(3)运行jenkins.war文件
nohup java -jar /usr/local/soft/jenkins.war --httpPort=8777 > /usr/local/soft/jenkins.log 2>&1 &
nohup--当服务休眠时jenkins服务依然运行
java -jar : 运行jenkins.war文件
--httpPort: http的端口号
/usr/local/soft/jenkins.log 2>&1: 启动jenkins生成日志放入该文件中
&:表示后台运行
浏览器中访问
进入之后选择安装推荐的插件(防止以后再安装)
然后记得修改一下账号密码 方便下次登录
jenkins集成jdk
jenkins集成git
由于jenkins需要从git远程仓库拉取项目代码,所以需要集成git。
(1)在jenkins所在的服务器安装git。
安装
yum install git -y
查看版本
git --version
(2)jenkins集成git软件
jenkins集成maven
集成maven的目的是为了给拉取的项目进行打包
在虚拟机中安装maven然后解压 然后配置环境变量配置本地仓库和阿里云镜像
配置环境变量的方式就是在/etc/profile中加入
配置maven的本地仓库和阿里镜像 配置文件中修改
<mirror>
<id>nexus-aliyun</id>
<mirrorOf>central</mirrorOf>
<name>Nexus aliyun</name>
<url>http://maven.aliyun.com/nexus/content/groups/public</url>
</mirror>
jenkins集成maven
测试:
在gitee上创建一个远程仓库
再在jenkins上创建一个maven任务
此时点击Build Now就可以
手动拉取代码
了
jenkins自动从gitee拉取代码
当gitee仓库中代码发生改变时,需要我们手动从git拉取代码,并手动完成编译和打包,这一步我们可以改为自动拉取代码的方式。
默认gitee不允许内网自动拉取代码,可以通过内网穿透的方式解决。
内网穿透软件有很多: 这里我们使用natapp
NATAPP-内网穿透 基于ngrok的国内高速内网映射工具
(1)设置内网穿透
(2)自动拉取代码
密码从gitee获取
现在jenkins就可以自己拉取代码了
jenkins完成自动化部署
我们的项目部署尽量不要和jenkins在同一台虚拟机下, 因为jenkins非常耗费资源,jenkins所在的服务器中需要安装和集成很多软件。如果我们能的项目也部署到当前jenkins所在的服务的话,那么势必会影响项目的性能。
scp /本地的文件 远程的账号@远程的ip:/远程的目录 此命令可以完成远程复制
远程复制时需要输入密码: 使用jenkins完成远程复制就必须配置免密复制。
设置免密操作
免密登录主要是方便jenkins服务器192.168.184.130的root用户把jar包拷贝、部署到应用服务器192.168.184.131上的过程。
在192.168.184.130【jenkins】机器上使用root用户生成秘钥注意此处是root用户
执行命令 ssh-keygen -t rsa 然后一直按回车
运行后会在当前用户的根目录生成一个.ssh文件夹
ssh文件夹中的文件描述
id_rsa :生成的私钥文件 id_rsa.pub:生成的公钥文件
接下来需要将公钥导入到认证文件中 执行命令
cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys
授权使ssh公钥生效
chmod 700 ~/.ssh chmod 600 ~/.ssh/authorized_keys
将authorized_keys文件拷贝到另一台应用服务器的root用户.ssh目录下
在应用服务器(192.168.184.130)上用root用户创建/root/.ssh文件夹 mkdir -p /root/.ssh
在jenkins服务器(192.168.184.131)上将pub公钥文件拷贝到应用服务器的.ssh目录下
scp -p ~/.ssh/id_rsa.pub root@192.168.184.131:/root/.ssh/authorized_keys
在jenkins192.168.184.130服务器上进行免密连接测试,此时就不需要输入密码了
上面已经配置好免密操作,之后让jenkins通过一个脚本完成复制功能。
复制功能
加入以下内容
#!/bin/bash
echo "部署的目录和项目名称"
DIR="/data/app"
projectName="my-boot"
echo "待部署的应用服务器,可多台"
server_ips="192.168.223.159"
for server_ip in ${server_ips[@]}
do
echo "ssh连接进行备份操作"
ssh -Tq -oStrictHostKeyChecking=no root@${server_ip} <<EOF
mkdir -p $DIR/backup/${projectName}
mkdir -p $DIR/${projectName}
if [ -f "$DIR/${projectName}/${projectName}.jar" ];then
mv $DIR/${projectName}/${projectName}.jar $DIR/backup/${projectName}/${projectName}-`date "+%Y%m%d_%H%M%S"`.jar
fi
EOF
echo "拷贝jar包到目标服务器的tmp目录"
scp -q -oStrictHostKeyChecking=no ${WORKSPACE}/target/*.jar root@${server_ip}:/tmp/${projectName}.jar
echo "ssh远程连接进行发布操作"
ssh -q -oStrictHostKeyChecking=no root@${server_ip} <<EOF
mv /tmp/${projectName}.jar $DIR/${projectName}/${projectName}.jar
EOF
done
echo "success"
然后在131台机器创建一个启动jar的脚本 vi start.sh 并修改权限为777
#!/bin/bash
set -e #任何命令出错就退出
set -o pipefail
APP_ID=my-boot
APP_DIR="/data/app"
nohup java -jar ${APP_DIR}/${APP_ID}/${APP_ID}.jar > release_out.log &
start_ok=false
if [[ $? = 0 ]];then
sleep 3
tail -n 10 release_out.log
sleep 5
tail -n 50 release_out.log
fi
aaa=`grep "Started" release_out.log | awk '{print $1}'`
if [[ -n "${aaa}" ]];then
echo "Application started ok"
exit 0
else
echo "Application started error"
exit 1
fi
再创建一个关闭jar脚本 vi stop.sh 并设置权限为777
#!/bin/bash
APP_ID=my-boot
ps aux | grep ${APP_ID} | grep -v "grep" | awk '{print "kill -9 "$2}' | sh
之后在execute shell 里加入这两个脚本
保存之后再提交我们的项目内容
这时jenkins中就开始自动拉取代码并部署启动了
访问被部署的服务器 可以看到自动化部署成功