本文转自测试人社区,原文链接: https://ceshiren.com/t/topic/32049
一,SonarQube 平台搭建
1.1, 介绍
Sonar 是一个用于代码质量管理的开放平台。通过插件机制,Sonar 可以集成不同的测试工具、代码分析工具,以及持续集成工具。与持续集成工具(例如 Hudson/Jenkins 等)不同,Sonar 并不是简单地把不同的代码检查工具结果(例如 FindBugs,PMD 等)直接显示在 Web 页面上,而是通过不同的插件对这些结果进行再加工处理,通过量化的方式度量代码质量的变化,从而可以方便地对不同规模和种类的工程进行代码质量管理。
- SonarQube(分析器):SonarQube是Sonar生态系统的核心组件,是一个开源的代码质量管理平台。
1.2, sonarqube 技术架构
1.3,Windows环境下载
1.4, Linux环境部署
(1)创建容器网络 : docker network create sonarqube
(2)创建数据库容器实例 :
(3)创建sonarqube容器实例,可以通过-Xms4g -Xmx4g增加下ES的堆内存大小
- mac环境需要加 -e SONAR_SEARCH_JAVAADDITIONALOPTS=“-Dbootstrap.system_call_filter=false”
(4)个别平台存在的 CONFIG_SECCOMP_FILTER 问题,解决方法如下:
(5)打开登陆页面
- 地址:
http://127.0.0.1:9000/
- 默认账号密码: admin/admin
(6)环境配置
- 划分组与用户
- 生成 token
- 环境变量设置
- 为了方便命令复用,后面命令中可变内容使用环境变量来表示
$SQ_HOST
二,SonarScanner 使用
2.1 工具下载
- SonarScanner(扫描器):用于将代码提交到SnaorQube进行分析的工具。
- 下载成功后,检查是否配置成功
sonar-scanner -h
三, sonarqube maven 项目分析
3.1 maven 全局配置
3.2 使用特定版本 scanner maven 插件
3.3 代码分析基本命令
3.4 maven 单模块项目代码分析
- 使用命令:
3.5 maven 多模块项目代码分析
- 使用命令:
3.6 sonarqube 多语言代码分析
- 使用命令:
3.7 spring boot 项目代码分析
- 使用命令:
3.8 电商项目代码分析
- 使用命令:
四, sonarqube gradle项目代码分析
4.1 插件与配置
4.2 gradle代码分析命令
五, sonarqube api使用
5.1 价值
5.2 体系
5.3 项目徽章 - 质量门禁
页面展示
接口调用
5.4 项目指标徽章
页面展示
接口调用代码展示
5.5 自定义规则
- 可以针对质量门禁等指标进行自定义规则,然后在Rules处修改或者添加自定义的规则