Docker平台下创建Jenkins Worker节点

1.镜像地址

https://github.com/jenkinsci/docker-jnlp-slave

2.Java Web Start(jnpl)方式部署Worker节点

https://wiki.jenkins-ci.org/display/JENKINS/Distributed+builds#Distributedbuilds-LaunchslaveagentviaJavaWebStart

3.具体步骤

3.1.打开Jenkins Server的JNPL代理端口

Jenkins > Manage Jenkins > Configure Global Security > Enable Security > Fixed > 输入任意未被占用端口

3.2.新建节点

Jenkins > Manage Jenkins > Manage Nodes > New Node > 输入节点名(很重要,我起名“agent-2”) > Permanent Agent > 远程目录随便填写 > Save
完成上述之后,这个时候节点是红色的叉叉;你可以在节点列表点击节点名称进去查看jnpl的文件地址下载到本机运行Worker也可以利用我这个例子Docker中运行Worker.

3.3.Docker运行Worker(两种方式)

依赖上述Docker镜像,注意节点名称必须一致,我这里新建的节点名叫“agent-2”。

3.3.1 Swarm方式

docker service create --name jenkins-agent-2 --user root jenkinsci/jnlp-slave -url http://10.47.192.7:8080/ 3083d678be6893f8ecd37d02972830c61baa59d29ae831c42058a24b65150c34 agent-2

3.3.2 Run方式

docker run -d --name jenkins-agent-3 \
--add-host "registry.nakedhub.cn:172.16.1.12" \
-e JENKINS_URL="http://139.224.47.139:8080/" \
-e JENKINS_NAME="internal" \
-e JENKINS_SECRET="e481b9d6cbcf20d5d841396b6c64cc93c22d7d00f6ef791cbc9f329761d9d961" \
--user root jenkinsci/jnlp-slave

4.注意

Jenkins的Docker Publish Plugin插件有BUG,远程镜像仓库安全登录校验没效果,构建Push到远程私有镜像仓库会出现”denied: requested access to the resource is denied”,需要手动处理;有二种方式。

4.1.第一种方式-Copy宿主机的远程仓库登录配置信息到Worker中

docker cp ~/.docker/config.json jenkins-agent-2:/home/jenkins/.docker/

4.2.第二种方式-Docker CLI安装完毕之后手动触发登录

Docker CLI会安装在(/var/lib/jenkins/tools/org.jenkinsci.plugins.docker.commons.tools.DockerTool/Docker-1.13.0-rc3/docker/bin)中。

./docker -H tcp://10.47.193.129:4243 login -u alittlebrain@qq.com -p 123456 registry-internal.cn-hangzhou.aliyuncs.com
### 配置 Docker Swarm 中的 Jenkins 使用 JaCoCo 实现自动化构建和代码覆盖报告 #### 安装并配置 Jenkins 和 JaCoCo 插件 为了使 Jenkins 能够处理 Java 项目的静态分析以及生成 JaCoCo 测试覆盖率报告,在启动 Jenkins 前需确保已安装了必要的插件。这可以通过在容器初始化脚本中指定 `install-plugin` 参数来完成。 ```bash docker run --name jenkins \ --restart always \ -p 8080:8080 \ -p 50000:5000 \ -v /var/jenkins_home:/var/jenkins_home \ -d jenkins/jenkins:2.387.1-lts \ java -jar /usr/share/jenkins/ref/plugins-manager-cli.jar install jacoco coverage-reporter-api[^3] ``` 上述命令不仅会拉取特定版本的 Jenkins 映像,还会自动安装 JaCoCo 及其依赖项之一——Coverage Reporter API 插件。 #### 创建多阶段管道定义文件 (Jenkinsfile) 对于 Spring Cloud 应用程序而言,推荐采用声明式的 Pipeline-as-code 方法编写 Jenkinsfile 来描述 CI/CD 工作流。下面是一个简单的例子: ```groovy pipeline { agent { label 'swarm-node' } stages { stage('Checkout') { steps { git branch: 'main', url: 'https://github.com/example/spring-cloud-app.git' } } stage('Build & Test with Maven') { environment { MAVEN_HOME = tool name: 'Maven_3.6.3', type: 'hudson.tasks.Maven$MavenInstallation' } steps { sh "${MAVEN_HOME}/bin/mvn clean verify" } post { always { junit '**/target/surefire-reports/*.xml' archiveArtifacts artifacts: '**/target/**/*.war,**/build/libs/*.jar', allowEmptyArchive: true } } } stage('Generate Code Coverage Report') { steps { step([$class: 'JacocoPublisher']) } } // 更多部署到 Docker Swarm 的逻辑... } } ``` 此 Groovy 脚本定义了一个完整的持续交付流程,其中包括检出源码仓库、编译打包应用程序、运行单元测试并将结果上传给 Jenkins,最后通过调用内置步骤生成 JaCoCo 报告。 #### 设置 Docker Swarm Service for Jenkins Master and Agents 为了让 Jenkins master 和 slave nodes 形成一个高可用的服务网格,可以按照如下方式设置服务: ```yaml version: "3" services: jenkins-master: image: jenkins/jenkins:2.387.1-lts ports: - "8080:8080" - "50000:50000" volumes: - ./jenkins-data:/var/jenkins_home deploy: replicas: 1 restart_policy: condition: on-failure jnlp-slave: image: jenkins/inbound-agent:latest depends_on: - jenkins-master command: ['jnlp'] deploy: mode: global labels: com.example.role: build-worker ``` 这段 YAML 文件用于创建两个独立但相互关联的服务实例:一个是作为主节点负责调度任务;另一个则是工作节点执行实际的任务操作。注意这里设置了全局模式下的 JNLP Slave 数量不受限于副本数目的约束[^4]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值