Jenkins是一个开源软件项目,是基于Java开发的一种持续集成工具,用于 监控持续重复的工作,旨在提供一个开放易用的软件平台,使软件项目可以 进行(持续集成)
Index of /war-stable/2.164.1
nohup java -jar /usr/local/jenkins.war --httpPort=8777 > /usr/local/jenkins.log 2>&1 &
nohup:当服务器休眠时 该软件还在运行
java-jar :执行war或jar文件
--httpPort:http的端口号
&:后台运行
http://192.168.61.132:8777/
项目通过jenkins从gitee拉取后需要编译。---javac. 所以 jenkins需要集成jdk
jenkins需要从远程仓库拉取代码 所以需要集成git
yum install -y git
我们现在很多项目都是maven的项目架构,所以我们jenkins从远程仓 库拉取的代码必须有maven管理依赖jar包
(1)gitee默认不允许内网触发。----必须要配置内网穿透
(2) 修改gitee远程仓库
(1)修改idea中的代码并提交到gitee上,会自动触发jenkins---拉取--编译---打包
思考: 我们的项目和jenkins是不是都在一台服务器上。 因为jenkins它所在的服务器非常耗费资源,因为jenkins本身要集成很多软件。如果这时项目也部署到当作jenkins所在的服务器,势必会导致项目在后期运行时由于资源不够,而导致无法运行。 所以我们的项目需要单独再一个服务器运行。
思考: jenkins打包好的项目jar在自己所在的服务器,而项目运行需要在其他服务器。需要把jenkins上打包好的jar复制到其他服务器。cp只能在本机进行复制。 scp 远程复制。
scp scp jenkins-0427-0.0.1-SNAPSHOT.jar [email protected]:/
scp:远程复制的命令
demo111: 被复制的文件
root@远程的ip:/远程的目录
我们再远程复制时需要输入另一台服务器133的密码. 由于后期需要jenkins软件帮你完成远程的复制功能。所以我们需要设置133这台服务免密操作。
(1)在132生成密钥
ssh-keygen -t rsa --一直回车
(2)接下来需要将公钥导入到认证文件中
cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys
(3)如果希望ssh公钥生效需满足至少下面两个条件:
.ssh目录权限必须为700 r4 w2 x1
.ssh/authorized_keys文件权限必须是600
(4)给文件授权
chmod 700 ~/ .ssh
chmod 600 ~/ .ssh/authorized_keys
(5)将authorized_keys
文件拷贝到另一台应用服务器的root用户.ssh目录下
# 在应用服务器(192.168.61.133)上用root用户创建/root/.ssh文件夹
mkdir -p /root/.ssh
# 在jenkins服务器(192.168.61.132)上将pub公钥文件拷贝到应用服务器的.ssh目录下
scp -p ~/.ssh/id_rsa.pub [email protected]:/root/.ssh/authorized_keys
(6)测试
从132复制文件到133发现无需输入密码。
(1)配置脚本
#!/bin/bash
echo "部署的目录和项目名称"
DIR="/data/app"
projectName="my-boot"echo "待部署的应用服务器,可多台"
server_ips="192.168.223.167"
for server_ip in ${server_ips[@]}
doecho "ssh连接进行备份操作"
ssh -Tq -oStrictHostKeyChecking=no root@${server_ip} <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
EOFecho "拷贝jar包到目标服务器的tmp目录"
scp -q -oStrictHostKeyChecking=no ${WORKSPACE}/target/*.jar root@${server_ip}:/tmp/${projectName}.jarecho "ssh远程连接进行发布操作"
ssh -q -oStrictHostKeyChecking=no root@${server_ip} <mv /tmp/${projectName}.jar $DIR/${projectName}/${projectName}.jar EOF
done
echo "success"
创建一个启动脚本长度
(1)编写项目的启动脚本
touch start.sh
vi start.sh
把下面的内容放入start.sh中
#!/bin/bash
set -e #任何命令出错就退出
set -o pipefailAPP_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
(2)关闭脚本
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
(3)修改脚本权限
(4) 修改jenkins的权限
(5) jenkins完成自动化拉取---编译---打包----部署----