jenkins+固定agent节点+maven+sonarqube+docker

说来惭愧:jenkins+动态slave没整出来,因为 本打算使用kaniko做容器化构建的,所有的配置都是按照k8s集群中部署来配置的,但是搞了很长时间,就是不行.不是驴不走就是磨不转.治好退而求其次.如果哪位大神整出来了,使用kaniko动态slave的部署方式,还望不吝指点一二.

感谢感谢.

先决条件

服务名称 版本号 部署位置
jenkins-version 2.486 k8s
k8s-version 1.24.14 k8s
maven-version 3.9.9 jenkins-agent
sonar-version 4.8.0.2856 jenkins-agent
java-version jdk-17 jenkins,jenkins-agent
jenkins插件 sonarqube scanner for jenkins jenkins
git plugins jenkins

说明一下,我这里安装的maven,sonar-scanner都是使用二进制安装的.参考个人的构建环境自己到github上下载对应版本的二进制包即可.

jenkins页面配置的信息

dashboard -->系统管理--> system -->jenkins Location

jenkins Url:    http://test-jenkins.com:30112/  这里因为我使用的是kubesphere作为k8s管理,所以jenkins部署好之后创建了个ingress.具体咋创建自己研究下.

同级设置sonarqube全局环境变量:

说明下:设置这些配置信息主要是为了生成环境变量.可以供全局使用.

serverurl 这里配置ide是sonar页面的url,jenkins-agent可以访问的地址.

token,是在凭据管理中创建的,从sonarqube页面中创建的用于jenkins与sonarqube连接认证用.

配置共享库

这里就不做过多解释了.之前文档有相关介绍,

### 配置 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、付费专栏及课程。

余额充值