部署Jenkins
- 创建本地数据保存目录
mkdir /root/jenkins
。 - 启动容器
docker run -itd --name jenkins \
-u root \
-p 8080:8080 -p 50000:50000 \
--env JAVA_OPTS="-server -Xms512m -Xmx1024m -XX:PermSize=256m -XX:MaxPermSize=512m" \
-v /root/jenkins:/var/jenkins_home \
-v /var/run/docker.sock:/var/run/docker.sock \
jenkinsci/blueocean:latest
参数说明
-u root
: Jenkins容器用户uid为1000,而我们前面创建的目录Jenkins用户不一定能访问到,因此我们此处以root用户来运行Jenkins容器。也可以用当前用户来运行,或者chmod 777 /root/jenkins
。建议以root用户运行,方便后续在容器内安装软件等操作。-p 8080:8080 -p 50000:50000
: 其中的50000端口用于master和slave的通信,8080端口用于前端界面访问。-
--env ...
:如果我们的机器配置较低,内存较小,很可能启动容器的时候,因为内存不足而导致容器被杀死137退出。建议启动容器的同时,配置一下java环境变量,约束下内存使用。
其中的含义如下:- -Xms JVM初始分配的堆内存
- -Xmx JVM最大允许分配的堆内存,按需分配
- -XX:PermSize JVM初始分配的非堆内存
- -XX:MaxPermSize JVM最大允许分配的非堆内存,按需分配
参考: https://blog.csdn.net/baidu_37107022/article/details/78277027
Java 虚拟机具有一个堆,堆是运行时数据区域,所有类实例和数组的内存均从此处分配。堆是在 Java 虚拟机启动时创建的。“在JVM中堆之外的内存称为非堆内存(Non-heap memory)”。
可以看出JVM主要管理两种类型的内存:堆和非堆。简单来说堆就是Java代码可及的内存,是留给开发人员使用的;非堆就是JVM留给自己用的。
-
-v /root/jenkins:/var/jenkins_home
: 挂载本地目录到容器中作为工作目录。 -
-v /var/run/docker.sock:/var/run/docker.sock
: 后续我们可能使用其他docker容器作为agent,因此需要将docker socket文件挂载到容器中,才能启动docker容器。 - 最后,容器镜像建议使用blueocean版本,可以可视化配置、查看流水线运行状况。也可以使用
jenkins/jenkins:lts
版本。
Jenkins基本使用
设置用户名密码
- 查看初始admin密码
cat /root/jenkins/secrets/initialAdminPassword
- 在前端界面打开部署Jenkins的机器地址及端口,如
192.168.1.1:8080
,在界面上输入前面得到的密码,就能使用Jenkins了。
其他说明
Jenkins架构说明
Jenkins是一种主从架构,有一个master和多个slave,master负责提供界面、处理HTTP请求及管理构建环境,汇总构建结果;slave是一个在远程机器上运行的Java可执行文件,构建的执行则由Jenkins slave负责。(master也可以执行构建操作,默认executor数量为2个,表示能并行执行两个Job。)
- node:节点,指包含Jenkins环境及有能力执行项目的机器。Master和Slave都被认为是节点。一个Master可以关联多个Slave用来为不同的Job或相同的Job的不同配置来服务。
• executor:执行器,是真正执行项目的单元。一个执行器可以被理解为一个单独的进程(事实上是线程)。在一个节点上可以运行多个执行器(添加节点的时候指定)。
• agent:代理,在概念上指的是相对于Jenkins master的一种角色,实际上是指运行在机器或容器中的一个程序,它会连接上Jenkins master,并执行Jenkins master分配给它的任务。
定时备份数据
通过上面方法启动的容器,只要定时打包备份/root/jenkins
目录就可以了。升级Jenkins版本时,直接使用该目录,使用新镜像重新启动容器就可以了。
调整executor数量。
通过executors.groovy
groovy脚本文件,重新打包镜像,可以修改executor的数量,如调整为5个。
import jenkins.model.*
Jenkins.instance.setNumExecutors(5)
Dockerfile
FROM jenkins
COPY executors.groovy /usr/share/jenkins/ref/init.groovy.d/executors.groovy
问题解决
- 启动容器时,报
Error response from daemon .... iptables failed
原因是docker启动后,iptables规则更新过。只需要重启docker即可。systemctl restart docker