[Tech] 我用Docker玩Jenkins

“CI使生活更美好”,为了充分地使用Jenkins实现多项目的持续集成,我们可以使用如下图的Server-Agent架构,即配置一个Jenkins服务器,再配置若干个Jenkins agent,随后在Jenkins服务器上将这些agent添加为节点。随后当有CI项目便都在agent服务器上执行。

《[Tech] 我用Docker玩Jenkins》 Jenkins Agent-Server架构

今天就和大家讲述一下我使用Docker配置Jenkins以及其节点的经历吧。

step 1. 创建Jenkins容器

这里我使用jenkins/jenkins这个镜像,

docker pull jenkins/jenkins

用这个镜像创建Docker容器(这里我选择了50000端口):

docker run -d -p 50000:8080 jenkins/jenkins:latest

《[Tech] 我用Docker玩Jenkins》 Jenkins容器创建

容器创建好之后,就可以在http://localhost:50000上看到Jenkins的引导配置页面啦。

《[Tech] 我用Docker玩Jenkins》 jenkins引导页面.png

随后去Jenkins容器查看所需密码:

docker exec -it ${CONTAINER_ID} bash
# 进入 Jenkins 容器
cat /var/jenkins_home/secrets/initialAdminPassword
# 查看密码

将查到的密码填入,随后就可以正式配置Jenkins啦,建议选择推荐的插件安装哦。

《[Tech] 我用Docker玩Jenkins》 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}
    

    《[Tech] 我用Docker玩Jenkins》 agent ip

  • 此时登录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便顺利连接上了。

《[Tech] 我用Docker玩Jenkins》 Jenkins添加节点

新建一个项目,在”限制项目的运行节点”中填写相应的节点。

《[Tech] 我用Docker玩Jenkins》 项目节点配置

然后项目就可以在指定agent容器里运行啦~
同样地,可以配置多个agent容器,如果有多个CI项目的话,就可以并行执行了。

    原文作者:敲代码的密斯想
    原文地址: https://www.jianshu.com/p/ada4aa64bc77
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞