Jenkins详细使用教程
目次1. 什么是Jenkins?
2. 为什么使用Jenkins?
3. 安装Jenkins
3.1 下载相干文件
3.2 解压Linux版本的JDK
3.3 设置JDK环境
3.4 运行jenkins.war
3.5 安装完成
4. 访问Jenkins
5. 修改密码
6. 集成JDK
7. Jenkins集成Git
7.1 使用Jenkins拉取Git仓库中的代码
8. Jenkins集成Maven
8.1 在Jenkins所在的服务器安装Maven
8.2 设置环境变量
8.3 修改maven设置文件(当地仓库和阿里云远程仓库所在)
8.4 Jenkins拉取Maven项目
8.4.1 安装maven插件
8.4.2 jenkins集成maven软件
9. 自动拉取
9.1 表里穿透
9.2 jenkins安装gitee插件
9.3 修改item使命的设置
9.4 修改gitee仓库的设置
10. 自动化摆设
10.1 免密复制操作
10.2 在Jenins远程复制的脚本
10.3 启动项目标shell脚本
10.4 关闭的脚本
10.5 在jenkins设置中引入关闭和启动脚本
1. 什么是Jenkins?
Jenkins是一个开源软件项目,是基于Java开发的一种连续集成工具,用于监控连续重复的工作,旨在提供一个开放易用的软件平台,使软件项目可以举行连续集成。
2. 为什么使用Jenkins?
https://i-blog.csdnimg.cn/direct/5e627073a84d49aa9e8755282d8b614f.png
https://i-blog.csdnimg.cn/direct/31ec84ee038a4c2499c522c53a071ff7.png
总的来说就是当你在idea写好代码上传到git上,jenkins帮你拉取文件,并且可以摆设到Linux上,以便于测试。
3. 安装Jenkins
必须在linux体系上安装了jdk,而且jdk的版本是[11~20)之间。如果你的jdk版本是8的话,前面统统正常,但到了背面安装插件就会报错。
3.1 下载相干文件
http://mirrors.jenkins.io/war-stable/latest/jenkins.war
https://i-blog.csdnimg.cn/direct/854b19da9a6743d8ac8c2afbd498ace4.png
3.2 解压Linux版本的JDK
tar -zxvf xxxx.tar.gz 3.3 设置JDK环境
[*]vi /etc/profile
[*]在文件的末了加上:export JAVA_HOME=/usr/app/jdk17
export PATH=$JAVA_HOME/bin:$PATH
[*]环境设置好后:source /etc/profile。
先运行yum install fontconfig:fontconfig 是一个机动的字体设置和选择体系,用于定制字体查找规则并提高字体的可访问性和可读性。
3.4 运行jenkins.war
nohup java -jar /usr/app/jenkins.war--httpPort=8777 >/usr/app/jenkins.log 2>&1 & 上面命令是在Linux体系中以背景方式启动Java应用程序(具体来说是Jenkins)而不占用终端会话。
[*]nohup:这个命令意味着“不挂断”。它使得启动的进程不会因为终端会话竣事而被终止。
[*]java -jar /usr/app/jenkins.war:这部分启动了Java应用程序。java -jar是运行Java Web应用程序的标准方式,/usr/app/jenkins.war是Jenkins应用的WAR文件路径。
[*]--httpPort=8777:这是通报给Jenkins应用的一个参数,指定了HTTP服务监听的端口为8777。
[*]>/usr/app/jenkins.log:这将标准输出重定向到/usr/app/jenkins.log文件,记载Jenkins运行时的全部输出信息。
[*]2>&1:这将标准错误输出(通常为文件形貌符2)重定向到与标准输出类似的地方(这里是指向jenkins.log)。这样做的目标是将全部输出(包罗错误信息)都归并到同一个日记文件中。
[*]&:末了的符号&表示命令应该在背景运行,立即返回控制台,使用户可以继续实行其他命令,而Jenkins应用则在背景连续运行。
3.5 安装完成
查看日记:
tail-100 jenkins.log 出现下面这种,阐明安装完成。
https://i-blog.csdnimg.cn/direct/07130876fcf94a0b810ee63f082b5259.png
4. 访问Jenkins
即可访问jenkins安装的Linux的所在:8777:https://i-blog.csdnimg.cn/direct/7cd47348db034ee39c6023530bb384ed.png
运行得到管理员密码:
https://i-blog.csdnimg.cn/direct/17a74ab29c9a472a9283088f54cfcf03.png
https://i-blog.csdnimg.cn/direct/31bb3c517caa49b49f798135734ef432.png
等待安装全部需要的依靠:https://i-blog.csdnimg.cn/direct/7d585c39bdc14cec8170c8a3bb9b7c3a.png
等待进度条满:
https://i-blog.csdnimg.cn/direct/6803690783d144b9a8e752df8ab3253d.png
创建用户:https://i-blog.csdnimg.cn/direct/12aae50cd167418e83ca4cef273c2a5e.png
https://i-blog.csdnimg.cn/direct/ccd2e08e1c294ff2b638257e7d37b89a.png
5. 修改密码
https://i-blog.csdnimg.cn/direct/6c9290ef7a1f4d6daa44f8c68ebcf84e.png
在页面下方有password。https://i-blog.csdnimg.cn/direct/8d40226b206d4946adfdf7568ec6a426.png
6. 集成JDK
找到Tools:
https://i-blog.csdnimg.cn/direct/00302099ad224f64ad9423b1f11e7ab4.png
添加JDK:
https://i-blog.csdnimg.cn/direct/f941a7ce8e624346a6fcb364f24963cf.png
7. Jenkins集成Git
因为jenkins自动从git远程仓库拉取代码,以是要在jenkins所在的服务器上安装git。
yum install -y git 再找到Tools:https://i-blog.csdnimg.cn/direct/6e0c72b8a65e44398917d0d6456a9925.png
找到Git:https://i-blog.csdnimg.cn/direct/f72de692523548e5bc93e4db9b33f6b8.png
如果你的Linux安装了git这里就不会报红了。
7.1 使用Jenkins拉取Git仓库中的代码
创建Item:
https://i-blog.csdnimg.cn/direct/78205efa8be04adda87a96f8bb8006db.png
完成新建:https://i-blog.csdnimg.cn/direct/8c75198c3ba944469603a26be309ae98.png
创建完毕后,找到源码管理:
https://i-blog.csdnimg.cn/direct/a40f3488d89241d1890e953aa593827c.png
输入你的仓库所在:
https://i-blog.csdnimg.cn/direct/6d0eb447cb1344ccb7ef526f6a30e07c.png
添加jenkins:https://i-blog.csdnimg.cn/direct/5d54586ad35a49118590dd933e83e4f0.png
填写好后,点至生存:
https://i-blog.csdnimg.cn/direct/1997cda6d7d44236baad1a55be460f4c.png
现在jenkins无法自动拉取代码。(当仓库中的代码发生改变时无法自动拉取)
https://i-blog.csdnimg.cn/direct/b312bd0ad80143aeb2d2f3c2b6e90e24.png
结果:
https://i-blog.csdnimg.cn/direct/7c1b0c6b4ee442bebba7a29e41c21509.png
8. Jenkins集成Maven
由于Jenkins自己不能对代码举行打包,以是我们需要集成maven,而且我们的项目几乎100%都是maven构建的项目。
8.1 在Jenkins所在的服务器安装Maven
https://i-blog.csdnimg.cn/direct/631e84db9d1745808bcecc4c5db884a0.png
8.2 设置环境变量
[*]vi /etc/profile
[*]在文件的末了加上:export MAVEN_HOME=安装路径
export PATH=$MAVEN_HOME/bin:$PATH
[*]环境设置好后:source /etc/profile
查看:
https://i-blog.csdnimg.cn/direct/3630c911367d4f7cb6a06547f921a622.png
8.3 修改maven设置文件(当地仓库和阿里云远程仓库所在)
https://i-blog.csdnimg.cn/direct/48dc6fbab8414016a75875dc8268a2c0.png
8.4 Jenkins拉取Maven项目
8.4.1 安装maven插件
https://i-blog.csdnimg.cn/direct/b809f3a951fe4f848f96a22e3a764e43.png
8.4.2 jenkins集成maven软件
https://i-blog.csdnimg.cn/direct/7a984d46b75947e89fbf428f2a6ce5fa.png
找到Git,设置Git:
https://i-blog.csdnimg.cn/direct/58082881d1ad445f9816b54721126bf9.png
9. 自动拉取
gitee仓库的代码,默认gitee不允许内网拉取。这里计划一个知识点叫做内网穿透。
9.1 表里穿透
通常个人电脑无论是毗连WIFI上网还是用网线上网,都是属于局域网里边的,外网无法直接访问到你的电脑,内网穿透可以让你的局域网中的电脑实现外网访问功能。
使用nat:
https://i-blog.csdnimg.cn/direct/aff947a06ed24bca9c2eb9b2feb45779.png
NATAPP1分钟快速新手图文教程 - NATAPP-内网穿透 基于ngrok的国内高速内网映射工具
9.2 jenkins安装gitee插件
https://i-blog.csdnimg.cn/direct/3613545a9a7843079029894423eda3f0.png
9.3 修改item使命的设置
https://i-blog.csdnimg.cn/direct/91f42dbbaf524fbc84ab46842fe9376a.png
天生Gitee WebHook 密码:
https://i-blog.csdnimg.cn/direct/83e7cc49d5b84883a029feaf1bc3e959.png
9.4 修改gitee仓库的设置
https://i-blog.csdnimg.cn/direct/768a8108f02d46358cf8e2617a6cb6bc.png
添加WebHook:https://i-blog.csdnimg.cn/direct/35957be64e9c4f99b538d69469947a7f.png
10. 自动化摆设
用shell脚本。
jenkins软件需要大量集成第三方很多软件(maven、git、jdk...),如果我们的项目也摆设到该服务器下,势必导致项目性能弱。
以是把jenkins所在的服务下打包好的项目远程复制到其他服务器上,在其他服务器举行项目标启动和关闭。
scp xxx.jar root@远程ip:/远程路径
第一次摆设的时候需要输入密码。
10.1 免密复制操作
设置ssh免密登录
免密登录紧张是方便jenkins服务器的root用户到应用服务器的root用户上的jar包拷贝,摆设本就是jar包拷贝的过程。
在jenkins服务器上使用root用户天生秘钥留意此处是root用户。
$ ssh-keygen -t rsa
# 3次回车 运行后会在当前用户的根目次天生一个.ssh文件夹。
ssh文件夹中的文件形貌
[*] id_rsa : 天生的私钥文件
[*] id_rsa.pub : 天生的公钥文件
接下来需要将公钥导入到认证文件中:
$ cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys 如果希望ssh公钥生效需满足至少下面两个条件:
[*] .ssh目次的权限必须是700
[*] .ssh/authorized_keys文件权限必须是600
给对应文件授权:
$ chmod 700 ~/.ssh
$ chmod 600 ~/.ssh/authorized_keys 将authorized_keys文件拷贝到另一台应用服务器的root用户.ssh目次下:
[*]在应用服务器上用root用户创建/root/.ssh文件夹 mkdir -p /root/.ssh
[*]在jenkins服务器上将pub公钥文件拷贝到应用服务器的.ssh目次下
scp -p ~/.ssh/id_rsa.pub root@应用服务器ip:/root/.ssh/authorized_keys
在jenkins服务器上举行免密毗连测试:
ssh 应用服务器ip
https://i-blog.csdnimg.cn/direct/b242ad15356f4c249e6c1ab0f088e485.png
总结:
[*]在jenkin所在的服务器使用ssh-keygen -t rsa。
[*]把公钥加载到认证文件中cat ~/.ssh/id_rsa.pub >> ~/.ssh/authorized_keys。
[*]修改.ssh 和authorized_keys 的权限。
[*]把jenkins服务器上公钥远程复制到免密的服务器上。mkdir -p /root/.ssh scp -p ~/.ssh/id_rsa.pub root@应用服务器ip:/root/.ssh/authorized_keys。
10.2 在Jenins远程复制的脚本
https://i-blog.csdnimg.cn/direct/0709724c29574bc0b5f998381fbb0fef.png
#!/bin/bash
echo "部署的目录和项目名称"
DIR="/data/app"
projectName="my-boot"
echo "待部署的应用服务器,可多台"
# 部署项目的ip
server_ips="xxxxxxxx"
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"
作用:把jenkins打包的jar远程copy到指定的服务器下。
10.3 启动项目标shell脚本
https://i-blog.csdnimg.cn/direct/2a17f3016ec4400b8ef563fc17b3fc58.png
#!/bin/bash
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 10.4 关闭的脚本
https://i-blog.csdnimg.cn/direct/b811a6d8dcf54d74ae02ba3888222d1a.png
#!/bin/bash
APP_ID=my-boot
ps aux | grep ${APP_ID} | grep -v "grep" | awk '{print "kill -9 "$2}' | sh 10.5 在jenkins设置中引入关闭和启动脚本
sh $DIR/${projectName}/stop.sh
sh $DIR/${projectName}/start.sh https://i-blog.csdnimg.cn/direct/1a9655d349d24bf5a036ac695b231dee.png
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
页:
[1]