一、什么是Jenkins
Jenkins是一个开源软件项目,是基于Java开发的一种持续集成工具,用于监控持续重复的工作
集成: 该软件可以集成其他软件,来完成相应的功能。
二、为什么需要使用持续集成工具
三、如何搭建jenkins服务
因为jenkins本身就是用java语言写一个持续集成工具软件。 我们直接下载该软件,通过java命令运行该软件即可
下载后放在Xftp7中,然后用Xshell解压运行该jar包
nohup java -jar /usr/local/software/jenkins.war --httpPort=8777 > /usr/local/software/jenkins.log 2>&1 &
window浏览器访问jenkins
这里需要输入密码 tail /root/.jenkins/secrets/initialAdminPassword 用这串命令来获取密码
修改admin登录的密码
四、jenkins集成服务器上的JDK
jenkins它可以编译 源代码----集成JDK----通过集成的JDK完成编译功能
五、jenkins集成git
由于jenkins需要从git仓库拉取代码----jenkins需要集成git.
5.1 jenkins所在的服务安装git
yum install git
检验:
5.2 jenkins集成git
5.3 jenkins创建一个任务项
针对某个远程仓库做的拉取。
5.4 创建远程仓库
5.5 执行任务
正常在企业开发时,当git仓库代码发生改变,jenkins应该自动执行任务。 我们现在先手动执行任务。
查看构建历史记录的详情
六、jenkins集成maven
由于jenkins要完成打包----maven来做的。 而且我们的项目后maven架构的项目。通过maven下载相关的依赖。
6.1 jenkins所在服务器安装maven
6.2 解压并重命名
6.3 配置环境变量
刷新配置文件 source /etc/profile
验证环境变量配置是否正确
6.4 配置本地仓库和阿里云镜像
6.5 jenkins集成maven
6.6 jenkins安装maven依赖
6.7 创建maven的任务项
执行任务
七、自动从gitee远程仓库拉取并编译打包
一定gitee发生改变,会自动触发jenkins---builder now的功能。
默认gitee不允许内网访问,安装一个内网穿透软件NATAPP。
NATAPP1分钟快速新手图文教程 - NATAPP-内网穿透 基于ngrok的国内高速内网映射工具
7.1 jenkins上安装gitee依赖
修改gitee的配置
八、自动化部署
思考: 我们的项目和jenkins是不是都在一台服务器上。 因为jenkins它所在的服务器非常耗费资源,因为jenkins本身要集成很多软件。如果这时项目也部署到当作jenkins所在的服务器,势必会导致项目在后期运行时由于资源不够,而导致无法运行。
后期项目应该会和jenkins在不同的服务器。
思考: jenkins打包好的项目jar在自己所在的服务器,而项目运行需要在其他服务器。需要把jenkins上打包好的jar复制到其他服务器。cp只能在本机进行复制。 scp 远程复制。
scp qy158-jenkins-0.0.1-SNAPSHOT.jar root@192.168.223.159:/usr/local/software/
- scp: 远程复制的命令
- 本地的文件
- root@192.168.223.159:/usr/local/software/ 远程账户@远程的ip:/远程的目录
上面再复制时需要输入密码。而jenkins所在的服务器,肯定不会自动输入密码。所以需要保证从158到159之间可以免密操作
8.1:如何免密操作
8.1.1: 再158生成密钥- 包含公钥和私钥
ssh-keygen -t rsa
8.1.2:接下来需要将公钥导入到认证文件中
cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys
8.1.3:如果希望ssh公钥生效需满足至少下面两个条件:
.ssh
目录的权限必须是700 r4 w2 x1
.ssh/authorized_keys
文件权限必须是600给对应文件授权
$ chmod 700 ~/.ssh
$ chmod 600 ~/.ssh/authorized_keys将
authorized_keys
文件拷贝到另一台应用服务器的root用户.ssh目录下
# 在应用服务器(192.168.223.159)上用root用户创建/root/.ssh文件夹 mkdir -p /root/.ssh
# 在jenkins服务器(192.168.223.158)上将pub公钥文件拷贝到应用服务器的.ssh目录下
scp -p ~/.ssh/id_rsa.pub root@192.168.223.159:/root/.ssh/authorized_keys
测试:两台机器复制文件不再需要密码
8.2:如何自动把jenkins服务器的jar复制到应用服务器上
需要编译shell脚本----让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"
8.3:自动化启动和关闭项目
8.3.1:编写项目的启动脚本
touch start.sh
vi start.sh
把下面的内容放入start.sh中#!/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
修改start.sh的权限
关闭脚本
touch stop.sh
vi stop.sh
把下面的内容放入stop.sh中#!/bin/bash APP_ID=my-boot ps aux | grep ${APP_ID} | grep -v "grep" | awk '{print "kill -9 "$2}' | sh
修改权限
8.4:再jenkins中使用上面的启动和关闭的脚本