"CI使生活更美好",为了充分地使用Jenkins实现多项目的持续集成,我们可以使用如下图的
Server-Agent
架构,即配置一个Jenkins服务器,再配置若干个Jenkins agent,随后在Jenkins服务器上将这些agent添加为节点。随后当有CI项目便都在agent服务器上执行。
今天就和大家讲述一下我使用Docker配置Jenkins以及其节点的经历吧。
step 1. 创建Jenkins容器
这里我使用jenkins/jenkins
这个镜像,
docker pull jenkins/jenkins
用这个镜像创建Docker容器(这里我选择了50000端口):
docker run -d -p 50000:8080 jenkins/jenkins:latest
容器创建好之后,就可以在http://localhost:50000
上看到Jenkins的引导配置页面啦。
随后去Jenkins容器查看所需密码:
docker exec -it ${CONTAINER_ID} bash
# 进入 Jenkins 容器
cat /var/jenkins_home/secrets/initialAdminPassword
# 查看密码
将查到的密码填入,随后就可以正式配置Jenkins啦,建议选择推荐的插件安装哦。
step 2. 创建Agent容器
根据所要执行的CI项目选择一个Docker镜像创建容器后安装相关的依赖,或是直接用DockerFile构建一个镜像,这里我使用Dockerfile。
docker build -t agent:lts ${DockerFilePath}
step 3. 连通Jenkins和Agent
-
进入Jenkins容器,生成ssh-key:
ssh-keygen
在.ssh目录下查看公钥id_rsa.pub
cat .ssh/rsa_id.pub
-
进入Agent容器,生成ssh-key并在.ssh目录下创建authorized_keys文件
cd ~/.ssh >authorized_keys
将Jenkins的公钥复制在authorized_keys下,修改权限:
chmod 600 ~/.ssh/authorized_keys chmod 700 ~/.ssh
随后重启ssh服务,
/etc/init.d/ssh restart
-
查看agent的ip地址,之后会用哦:
docker inspect ${AGENT_ID}
-
此时登录Jenkins容器,输入上面查到的agent的ip地址:
ssh root@${AGENT_IP}
如果能够顺利登陆agent那台机器,就说明姿势正确哦,如果不能的话。
step 4. Jenkins项目配置节点
进入 Jenkins -> Nodes
,填写节点的工作目录,上面查看到的agent的IP地址等。如下图,这里有个小坑,当我使用SSH with private key
方式创建的Credentials
时,总是显示鉴权失败,折腾了好久。这时候我又添加了以Username with password
方式创建的Credentials
(需要知道agent容器的登录名密码,如果不知道,可以通过echo 'root:root' |chpasswd
的方式去添加)时,agent便顺利连接上了。
新建一个项目,在"限制项目的运行节点"中填写相应的节点。
然后项目就可以在指定agent容器里运行啦~
同样地,可以配置多个agent容器,如果有多个CI项目的话,就可以并行执行了。