Android持续集成--JENKINS+GRADLE+JACOCO+SONARQUBE(二)

本文详细介绍了如何安装和配置Jenkins,包括安装步骤、修改配置文件解决端口冲突、管理Jenkins脚本、安装与升级插件、权限管理、系统设置等关键步骤。

六.安装Jenkins

1. 安装Jenkins

2. 修改配置文件

安装后即可打开http://localhost:8080 或者用本机ip取代localhost 默认端口为8080,如果打不开,可查看安装目录下的jenkins.err.log文件,查明原因,如果是端口被占用,下面是两种解决方案,任选其一:

(1) 修改安装目录下的jenkins.xml文件,修改片段如下


修改后重新安装jenkins,选择repair, 修复完成后,访问 http://localhost:8081

(2) 使用命令行启动

进入到安装目录下使用命令 Java–jar jenkins.war –httpPort=8081 启动完成即可访问,如果没有jenkins.war 可以到此地址下载http://mirrors.jenkins-ci.org/war/latest/jenkins.war

3. 正常的启动界面

4. 管理jenkins脚本

进入Jenkins主界面,系统管理>>Jenkins CLI,按照说明,下载jar包,执行说明中的命令,会显示脚本都提供了哪些功能,把help替换成restart就会重启jenkins了

还有更简单的方法进行重启,在url后加命令,比如:http://localhost:8080/restart(重启) 或者reload(重新加载) 或者exit(关闭)

5.    安装插件

进入Jenkins主界面,系统管理>>管理插件>>可选插件

分别安装Android Lint Plugin,JaCoCo plugin,Gradle plugin,SonarQube Plugin, Role-based Authorization Strategy

6.    升级插件

系统管理>>管理插件>>可更新,升级Subversion Plug-in

7.    权限管理

如果有分组管理权限,实现不同用户组或不同用户拥有不同的权限可以参考此条,譬如:开发,管理层,测试人员想让不同的角色拥有不同的权限就可以利用插件Role-based Authorization Strategy来实现

(1)系统管理>>Configure Global Security

(2) 系统管理>>Manage andAssign Roles

(3) 管理角色,分配权限

添加好角色,比如开发,测试,管理层,相对应的权限根据实际情况来自行选择

(4) 分配角色

将注册好的用户添加好,然后分配之前已经建立好的角色,这样用户就继承了角色权限了

8. 系统设置

进入Jenkins主界面,系统管理>>系统设置

(1) 设置JDK,GRADL

(2) 设置SonarQube Runner

(3) 设置SonarQube

(4)设置邮件通知

1) 设置发送邮件的邮箱


2) 设置具体的选项

通过测试发送邮件,来验证填写是否正确,注意,如果是qq邮箱并且设置了独立密码,只需要填写独立密码即可,如果未设置smtp请到qq邮箱首页>>设置>>账户 开启smtp服务

(5)应用并保存

全部配置填写完毕,操作应用和保存按钮即可






Android持续集成--JENKINS+GRADLE+JACOCO+SONARQUBE(三)


### 配置 Docker Swarm 中的 Jenkins 使用 JaCoCo 实现自动化构建和代码覆盖报告 #### 安装并配置 JenkinsJaCoCo 插件 为了使 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]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值