拉取稳定版Jenkins镜像
注意:
docker拉取镜像的时候要拉取 jenkins/jenkins 而不是jenkins 要装稳定版,否则后面会有很多插件装不上
docker pull jenkins/jenkins:lts
挂载对应的容器卷
#给需要挂载的文件夹授权
mkdir jenkins_home
chmod 777 /docker/jenkins_home/
#启动容器
docker run -d -p 8090:8080 -p 8091:50000 --privileged=true --name jenkins_8090 -v /docker/jenkins_home:/var/jenkins_home -v /etc/localtime:/etc/localtime 55860ee0cd73
-d 后台运行镜像
-p 8090:8080 将镜像的8080端口映射到服务器的8090端口。
-p 8091:50000 将镜像的50000端口映射到服务器的8091端口
-v /data/jenkins_home:/var/jenkins_home /var/jenkins_home目录为容器jenkins工作目录,我们将硬盘上的一个目录挂载到这个位置,方便后续更新镜像后继续使用原来的工作目录。这里我们设置的就是上面我们创建的 /data/jenkins_home目录
-v /etc/localtime:/etc/localtime让容器使用和服务器同样的时间设置。
–name jenkins_8090 给容器起一个别名
http://mirror.esuni.jp/jenkins/updates/update-center.json
修改插件下载镜像源为清华镜像(可以先直接尝试一下是否可以安装成功)
# 修改xml
vim jenkins_home/hudson.model.UpdateCenter.xml
#将 https://updates.jenkins.io/update-center.json 替换为 http://mirror.esuni.jp/jenkins/updates/update-center.json
http://mirrors.tuna.tsinghua.edu.cn/jenkins/updates/update-center.json
# 修改jenkins/updetes/default.json文件
①把:“http://www.google.com/” 改成 “http://www.baidu.com/”
②把:“https://updates.jenkins.io/download” 全部替换成 “http://mirrors.tuna.tsinghua.edu.cn/jenkins”
sed -i 's#https://updates.jenkins.io/download#https://mirrors.tuna.tsinghua.edu.cn/jenkins#g' default.json
sed -i 's#https://www.google.com#https://www.baidu.com#g' default.json
sed -i 's#https://updates.jenkins.io/download#https://mirrors.huaweicloud.com/jenkins#g' default.json && sed -i 's#http://www.google.com#https://www.baidu.com#g' default.json
http://ip:9090/pluginManager/advanced
https://cdn.jsdelivr.net/gh/jenkins-zh/update-center-mirror/tsinghua/current/update-center.json
# 重启服务
docker stop jenkins_8090
docker start jenkins_8090
访问web页面 http://IP:8090/
去查看第一次登录的密码
#查看输出日志
docker logs jenkins_8090
#在日志中会有一段密码
Jenkins initial setup is required. An admin user has been created and a password generated.
Please use the following password to proceed to installation:
800c8b5201284979a1ea16c1893358d5
This may also be found at: /var/jenkins_home/secrets/initialAdminPassword
#或者也可以去它上面给的地址中查看密码
将密码填入上面的文本框中
等待一会后,开始安装插件
后续需要通过maven来构建我们的项目,所以需要在容器内安装mavne
# 将maven下载好后解压
unzip /mavne/apache-maven-3.8.6 -d ./
# 修改maven的镜像源
vim /mavne/apache-maven-3.8.6/conf/setting.xml
#将里面的镜像换为阿里云镜像
<mirror>
<id>alimaven</id>
<name>aliyun maven</name>
<url>http://maven.aliyun.com/nexus/content/groups/public/</url>
<mirrorOf>central</mirrorOf>
</mirror>
#增加软连接 (不需要进入到原来的路径也可以验证Maven安装)
ln -s /maven/apache-maven-3.8.6/bin/mvn /usr/local/bin/mvn
#验证是安装成功
mvn -v
下载适合的war包 https://mirrors.jenkins.io/war-stable/
我这里用的jdk1.8 所以下载的版本为jenkins 2.346.1
利用java命令启动
touch temp.txt
# 这种方式会在后台运行 不会被关闭
nohup java -jar jenkins.war --httpPort=8090 >temp.txt &
访问 ip:8090 后续操作同上4⃣️
创建一个任务
选择Git ,此时下面会提示git连接错误
可以配置下凭证
安装git
yum install -y git
# 安装完毕后验证一下
git --verison
设置需要构建的分支
配置maven路径
配置安装的maven路径
设置需要构建的pom文件路径
保存后开始构建
可以在构建中看到控制台输出(记得将maven的镜像地址换成阿里云地址
)
安装服务器连接插件 Publish Over SSH
进入配置后管理界面
选择这个选项
配置测试服务器连接
因为我们需要增加一台远程服务器,所以我们需要做一些配置信息
添加一台远程服务器
此时在原先的地方就有了我们刚添加的服务器
配置相关数据
构建后Post Steps
启动脚本问题会导致超时,从而导致启动不成功
可以设置超时时间为0 这样就可以不会因为超时而不成功
nohup java -jar /jenkins/build_jar/first1/*.jar &
# 这条语句会超时,原因是因为没有指明日志输出到哪里,控制台会一直等待
#修改为如下
nohup java -jar /jenkins/build_jar/first1/*.jar >/jenkins/build_jar/first1/mylog.log 2>&1 &
# 也可以简化为
nohup java -jar /jenkins/build_jar/first1/*.jar &>/jenkins/build_jar/first1/mylog.log &
数据流重定向就是将某个命令执行后应该要出现在屏幕上的数据传输到其他地方
# 标准输入:代码为0,使用<或者<<
# 标准输出:代码为1,使用>或者>>
# 标准错误输出:代码为2,使用2>或者2>>
# 若以>输出到一个已存在的文件中,那么这个文件会被覆盖
# > 覆盖写
# >> 追加写
jps|grep -v Jps|awk '{print $1}'
#将 xxxx写入xxx.txt
echo "xxxx">xxx.txt
#!/bin/bash
#获取程序运行的pid
ps -ef|grep jenkins_demo #会获取到两条记录 有一条是grep的数据
#利用grep -v 再次过滤 grep -v 需要过滤掉的信息
ps -ef|grep jenkins_demo|grep -v grep
#利用grep '需要的信息' 进行过滤
ps -ef|grep jenkins_demo|grep 'SNAPSHOT'
#获取打印出来的信息的第二列数据PID
`ps -ef|grep jenkins_demo|grep 'SNAPSHOT'|awk '{printf $2}'`
部署前shell操作(删除原来的包,同时关闭上一次运行的pid)
#!/bin/bash
#删除原来的包
rm -rf /jenkins/build_jar/first1
#传入一个参数
appname=$1
if [ -z $appname ]
then
appname='jenkins_demo'
fi
echo $appname
#获取pid
pid=`ps -ef | grep $appname | grep 'java -jar' | awk '{printf $2}'`
echo $pid
#如果pid为空的话,提示一下,否则执行kill命令
if [ -z $pid ]
#使用-z来判断是否是空值
then
echo "$appname not started"
else
kill -9 $pid
echo "$appname stoping..."
fi
#再次精准匹配 查看是否已经kill完 -w是精准匹配
check=`ps -ef|grep -w $pid |grep java`
if [ -z $check ]
then
echo "$appname pid:$pid is stop"
else
echo "$appname stop Failed"
fi
触发器可以通过一些事件触发Jenkins的自动构建,如:上传代码,合并代码等。
2.1 选择测试项目-配置-构建触发器,选择触发远程构建,将token粘贴在身份验证令牌处,保存
2.2 通过访问 JENKINS_URL/job/first/build?token=
TOKEN_NAME 观察项目是否进入构建队列
(GitLab GitHub)同理
3.1在Jenkins中安装Gitee插件(同上)
3.2在项目设置中配置Gitee令牌地址等
3.3增加webHooks管理
3.4添加post地址和token 这里的地址直接用上面Jenkins的链接,token则是刚才生成的密码
3.5尝试重新上传代码,可以发现现在会自动触发构建
1、快照依赖构建/Build whenever a SNAPSHOT dependency is built
2、触发远程构建 (例如,使用脚本)
3、job依赖构建/Build after other projects are built
4、定时构建/Build periodically
5、向GitHub提交代码时触发Jenkins自动构建/GitHub hook trigger for GITScm polling
6、定期检查代码变更/Poll SCM
在构建中Build periodically与Poll SCM接收的参数都是cron表达式
与标准的cron表达式不同,没有秒字段
cron表达式网站
第一个 * 表示每个小时的第几分钟,取值0~59
0 */1 * * *
H:每小时0分执行一次
第二颗 * 表示小时,取值0~23
* 15 * * * 表示每天下午3点
* 1 * * * 表示每天凌晨1点
第三颗 * 表示一个月的第几天,取值1~31
* 1 5 * * 表示每月5日凌晨1点
第四颗 * 表示第几月,取值1~12
* 15 5 1 * 表示每年一月5日15时的每一分钟执行
第五颗 * 表示一周中的第几天,取值0~7,其中0和7代表的都是周日
H (hash散列)
hash散列值,以job名取值,获取到以job名为入参的唯一值,相同名称值也相同,这个偏移量会和实际时间相加,获得一个真实的运行时间。
意义在于:不同的项目在不同的时间运行,即使配置的值是一样的,比如 都是15 * * * * ,表示每个小时的第15分钟开始执行任务,那么会造成同一时间内在Jenkins中启动很多job,换成H/15 * * * *,那么在首次启动任务时,会有随机值参与进来,有的会在17分钟启动 有的会在19分钟启动,随后的启动时间也是这个值。这样就能错开相同cron值的任务执行,减轻同一时间拉起的Job太多。
H的值也可以设置范围
H * * * *表示一小时内的任意时间
*/10 * * * *每10分钟
H/10 * * * *每10分钟,可能是7,17,27,起始时间定hash,后续不会变
45 3 * * 1-6 每个周一至周六,凌晨3点45 执行1次
45 3-5 * * 1-6 每个周一至周六,凌晨3点45 ,凌晨4点45,凌晨5点45 各执行1次
H(40-48) 3-5 * * 1-6 在40~48之间取值 其他同上
45 3-5/2 * * 1-6 每个周一至周六,凌晨3点45 ,凌晨5点45 各执行1次
45 0-6/2 * * * 0点开始,6点结束,每间隔2小时执行一次 0:45、2:45、4:45、6:45
如图 配置后会每天凌晨两点的某一分钟为我们构建 H 2 * * *
这个是由Jenkins服务发起对远程git仓库的访问,比较配置的分支上是否有新的内容,如果有则会发起一次构建,轮询频率控制是通过cron表达式控制。
点击发送测试信息的时候,提示**AuthenticationFailedException: 550 User has no permission**
错误
那就是授权出现了错误,此时就需要重新获取授权码再授权一次,但记得邮箱设置页面中已获得授权的设备一定要记得删除,防止自己的邮箱账号被盗
点击发送测试信息的时候,提示MailConnectException: Couldn't connect to host, port: smtp.163.com, 25; timeout 60000;
这个话是因为可能你使用的是Linux服务器,防火墙25端口没有开,有两种解决办法
1.开启防火墙25端口
注意:如果你和我一样使用的为阿里云服务器的话,阿里云为了安全考虑默认是关闭25端口的,如果你想要开启的话需要提交申请审批,大概需要3-5天
2.使用SSL协议号
我这里使用的是465端口,同时启用SSL协议
点击发送测试信息的时候,提示MessagingException: Got bad greeting from SMTP host: smtp.163.com, port: 465, response: [EOF]
,则查看使用的端口是否需要使用SSL协议
用来发送的邮箱要和管理员设置的邮箱一致
这样就可以开开心心的发邮件啦!以上这些坑不幸的我都踩到了