jenkins+docker 实现主从模式

本贴最后更新于 872 天前,其中的信息可能已经沧海桑田
前言:jenkins主从模式想必大家都不陌生,大家在学习过程中为了学习方便都在自己本地搭建了jenkins环境,然后通过javaweb方式实现,对于docker下实现主从模式大家好像兴趣挺大。今天就通过这篇文章给大家讲讲怎么玩,希望对大家有帮助。
二、环境准备
  1. 准备一台Linux服务器(云服务器、自建Linux服务器都可以)
  2. 在Linux服务器上安装docker
  3. 拉个jenkins镜像下来,再启动一个jenkins容器
  4. docker中把这个镜像jenkins/ssh-slave拉下来(jenkins提供的专门用来做主从的镜像)
  5. OK准备工作就做完了
三、准备开工
第一步:docker开启远程访问,需要开启2375端口,这个端口慎重开启(我用的是centos)
  1. 打开docker.service文件
    vim /usr/lib/systemd/system/docker.service
  2. 在docker.service文件的[Service]下添加如下内容
    [Service]
    ExecStart=
    ExecStart=/usr/bin/dockerd -H tcp://0.0.0.0:2375 -H unix://var/run/docker.sock
  3. 重新启动docker服务,让docker重新读取配置文件
    systemctl daemon-reload
    systemctl restart docker
  4. 验证,查看docker进程,如果docker守护进程在已经监听2375的tcp端口,就算成功开启了2375端口
    image.png
  5. 进一步验证,通过其他机子访问docker宿主机
    sudo docker -H tcp://139.129.130.123:2375 images
    上面这个命令相当于直接在docker宿主机上执行docker images命令,能正确返回就表示没问题
第二步:下载官网镜像(顺便再提一下,不要忘记了)
  1. docker pull jenkins/ssh-slave
第三步:以jenkins/ssh-slave为基础打一个有python3环境的新镜像
  1. 创建一个dockerfile目录
  2. 将项目执行依赖的python包文件放到dockerfile目录下(怎么生成依赖文件不写了,默认你们是高手都会)
    requests==2.24.0
    openpyxl
    ddt
    pytest
    selenium
    pymysql
    pyyaml==5.3.1
    faker
    jsonpath
    BeautifulReport
    unittestreport
    rsa
    pytest-html
    Appium-Python-Client
    
  3. 创建一个名为sources.list的文件(名字不能改必须是这个名字),加入如下内容
    在jenkins/ssh-slave镜像/etc/apt/目录下
    deb http://mirrors.163.com/debian/ buster main non-free contrib
    deb http://mirrors.163.com/debian/ buster-updates main non-free contrib
    deb http://mirrors.163.com/debian/ buster-backports main non-free contrib
    deb-src http://mirrors.163.com/debian/ buster main non-free contrib
    deb-src http://mirrors.163.com/debian/ buster-updates main non-free contrib
    deb-src http://mirrors.163.com/debian/ buster-backports main non-free contrib
    deb http://mirrors.163.com/debian-security/ buster/updates main non-free contrib
    deb-src http://mirrors.163.com/debian-security/ buster/updates main non-free contrib
    sources.list作用说明:官方提供的jenkins/ssh-slave并没有python,需要安装python就要去更新他的安装包,此时如果使用他默认的镜像源会非常慢,因此我们换一个更快的源,将它原来的文件覆盖掉就行了,这里要根据自己的版本号进行修改,我的是buster版本,当然你下载后也应该是和我的一样。
  4. 写Dockerfile
    FROM jenkins/ssh-slave:latest
    USER root
    WORKDIR /app
    ADD requirements.txt  /app
    ADD sources.list /etc/apt/
    RUN echo export JAVA_TOOL_OPTIONS="-Dfile.encoding=UTF-8" >> /etc/profile
    RUN apt-get -y update  && apt-get -y install python3 && apt-get -y install python3-pip && pip3 install -r requirements.txt -i https://pypi.douban.com/simple
    
  5. 执行镜像构建命令
    docker build -t jenkins/ssh-slave:v2.0 .
第四步:配置jenkins从节点
  1. 进到节点配置页面
    manage jenkins---> Slave Node(节点管理)--->ConfigureClouds
    image.png
  2. 你将看到如下页面
    image.png
  3. 点Add a new cloud下拉选择docker,点完来到如下页面
    image.png
  4. 点开Docker Cloud details进行配置,点开后页面如下
    image.png
  5. 点开Docker Agent templates,你将看到如下页面
    image.png
  6. 点开下图的高级选项
    image.png
  7. 高级选项具体配置如下图
    image.png
    image.png
  8. 配置完成后记得保存,最好是边配置边保存,养成好习惯。
第五步:将docker slave绑定到你的jenkins任务
  1. 新建任务,选择自由风格项目
    image.png

  2. 限制项目运行节点,选择新建的节点(Labels)
    image.png

  3. 配置git
    image.png

  4. 配置shell命令
    image.png

  5. 配置测试报告
    image.png

    image.png
    image.png

第六步:构建你的项目
  1. 开始构建后在你的构建队列那会看到如下图所示

image.png
2. 构建完成之后,点你的项目,来到这里会有构建记录,点进去可以看构建日志

image.png
3. 查看测试报告
image.png
4. 测试报告如下

image.png

6 操作
haili 在 2021-09-13 16:23:53 更新了该帖
haili 在 2021-09-13 16:12:23 更新了该帖
haili 在 2021-09-13 15:38:35 更新了该帖
haili 在 2021-09-13 15:06:07 更新了该帖 haili 在 2021-09-13 14:31:06 更新了该帖 haili 在 2021-09-13 14:26:31 更新了该帖
回帖
请输入回帖内容 ...