Jenkins系列——使用SonarQube进行代码质量检查
1.目标
之前已经写过一篇关于Jenkins和SonarQube的一篇博客《jenkins集成sonar》,本文在参考前文的基础上,做了详细的补充。
使用SonarQube进行代码质量检查,访问SonarQube Server,可以查看代码质量检查报告。
2.环境说明
jdk:sun JDK1.8.0_20 64bit
MySQL:5.7.13
sonarqube-5.6.zip(链接: https://pan.baidu.com/s/1miRtGog 密码: k3qn)
sonar-scanner-2.6.1.zip(链接: https://pan.baidu.com/s/1nvuNFw1 密码: 9gac)
Jenkins sonar插件——sonar-2.6.hpi(链接: https://pan.baidu.com/s/1kVulJmB 密码: yyqq)
SonarQube汉化插件——sonar-l10n-zh-plugin-1.11.jar(链接: https://pan.baidu.com/s/1hstBTjA 密码: pb4m)
①Jenkins系列文档自本篇起JDK版本采用sun jdk8+ 。
②SonarQube依赖条件详细参考SonarQube官方文档。
3.前置工作
3.1 jdk8+的安装
略。
3.2 MySQL的安装及建立sonar专用database
安装过程略。
使用如下语句建立database:
create database sonar default charset=utf8;
3.3 配置sonarqube-server
进入sonarqube-server安装目录 >> conf目录,编辑sonar.properties文件:
3.4 配置sonarqube-runner
进入sonarqube-runner安装目录 >> conf目录,编辑sonar-scanner.properties文件:
笔者后来在安装当前最新版本(6.3.1)时,发现sonar-runner还必须加如下配置:
sonar.login=admin
sonar.password=admin
注:admin/admin是sonar的管理员初始登录账号密码。
最终sonar-runner的配置如下:
3.5 验证SonarQube是否安装成功
启动sonarqube-server:
①在windows下启动失败请尝试用『以管理员身份运行』。
②如果SonarQube用的比较多,可以设置为服务。如此便不用每次都启动。
③在Jenkins中调用sonar,前提仍然是sonarqube-server已启动。
3.6 验证sonar-runner【可选】
(1)设置SONAR_RUNNER_HOME环境变量,值为sonar-runner安装位置
(2)设置path环境变量,增加 ;%SONAR_RUNNER_HOME%\bin
(3)新建sonar-project.properties文件,增加以下内容:
(4)进入源码位置,在控制台中执行sonar runner命令,看能够构建成功。
3.7 安装jenkins的sonar插件
方式一:通过上传sonar-*.hpi文件的方式安装,在没网络的情况下可能还要手动处理依赖插件。
方式二:在jenkins的『插件管理』中搜索sonar插件安装。
4.Jenkins配置
4.1 配置jdk
进入『系统管理』 >> 『Global Tool Configurationa』,配置如下:
从此篇文章起,jdk版本变成了1.8+。如果jdk一开始就是1.8+,此步配置应省略。
4.2 配置sonar-server
进入『系统管理』 >> 『系统设置』,配置如下:
4.3 配置sonar-runner
进入『系统管理』 >> 『Global Tool Configurationa』,配置如下:
4.4 新建并配置job【自由风格】
(1)配置sonar-project.properties,详见本文3.6 步骤(3)。最终效果如下:
(2)配置job
这里源码使用了码云的zheng项目,直接放到了该作业工作区的src目录之下。
5.构建结果
控制台输出如下:
返回作业,能看到sonarqube检查结果的链接图标:
点击接图标,可以看到该次构建结果:
SonarQube汉化请参考《SonarQube中文插件安装》。
6.总结
①SonarQube 需要JDK 和 数据库 的支持。在选择前需要阅读官方文档选择合适的版本。
②SonarQube 是一个独立的软件,不是一定要和jenkins 扯上联系,因此完全可以先独立验证SonarQube的可用性,再利用sonar插件和jenkins关联。
③SonarQube 需要对sonar-server 做配置才能进一步使用。扫描项目时需要提供项目的配置文件。
Jenkins系列——使用SonarQube进行代码质量检查的更多相关文章
- 在 k8s 中的 jenkins 集成 sonarqube 实现代码质量检查
不乱于心,不困于情,不畏将来,不念过往,如此安好 --<不宠无惊过一生>丰子恺 概述 关于在 k8s 中安装 jenkins 和 sornarqube 可以查看下面的文章: 在 k8s 中 ...
- Jenkins系列——使用checkstyle进行代码规范检查【升级版】
1.背景 在<Jenkins系列——使用checkstyle进行代码规范检查>一文中完成了ant实现代码规范检查的例子.但存在以下缺陷: 每个作业都需要配置一个不同的checkstyle ...
- jenkins集成sonarQube实现代码质量检查
1.sonarQube的简介 SonarQube是一款自动化代码审查工具,用于检测代码中的错误.漏洞和代码异味.它可以与你现有的工作流集成,以支持跨项目分支和拉取请求的连续代码检查. 其工作流程如下: ...
- Jenkins系列——使用checkstyle进行代码规范检查
1.目标 通过jenkins使用checkstyle对代码进行规范检查并生成html报告. 构建采用shell. 2.环境 checkstyle5.7(如果是Linux版本选用tar.gz格式) ap ...
- Jenkins+SonarQube实现C#代码质量检查
环境准备 SonarQube 项目创建 jenkins Windows构建节点配置 安装与SonarQube服务端相同版本jdk 安装sonar-scanner 并配置环境变量 安装Visual St ...
- git jenkins SonarQube手动代码质检
SonarQube代码质检:1.提交代码-->gitlab-->jenkins抓取-->sonarqube质量检测-->maven编译-->shell-->web集 ...
- 持续集成工具之jenkins+sonarqube做代码扫描
上一篇我们主要聊了下代码质量管理平台sonarqube的安装部署以及它的工作方式做了简单的描述和代码扫描演示:回顾请参考https://www.cnblogs.com/qiuhom-1874/p/13 ...
- 持续集成高级篇之Jenkins Pipeline 集成sonarqube
系列目录 前面章节中我们讲到了Sonarqube的使用,其实Sonarqube获取msbuild结果主要是执行三个命令,开始标记,执行msbuild,结束标记,这些都是命令,是非常容易集成到我们ci流 ...
- jenkins系列(11)-自动打tag升级篇
很久以前,小怪分享过一篇jenkins自动打tag的文章(jenkins系列1--自动打tag),经过在项目实战和改进,我们升级了方案,现在和大家分享.,希望大家在工作中能够用起来. 使用步骤: 1. ...
随机推荐
- 如何将ajax请求同步化
(function ($) { var a = ['test1', 'test2', 'test3', 'test4']; recursive(3, 'test').done(function (re ...
- 如何在VS2015中使用Git命令提示符
本文转载自 http://qkxue.net/info/176223/Visual-Studio-Git VS2015自带了Git插件,但有时候觉得Git控制台命令更方便些.VS中本身不能把Git B ...
- 3. 关于sql注入的综合题
关于sql注入的综合题 ----------南京邮电大学ctf : http://cms.nuptzj.cn/ 页面上也给了好多信息: 根据这个sm. ...
- 存储过程接收JSON格式数据
前端有可能一次性上传多笔记录,并使用JSON序列化. 现在在MS SQL Server 2016版本上,可以直接处理JSO数据. 如下面的前端序列化的数据: DECLARE @json_string ...
- 手动配置webpack之React
安装 1.安装react转译相关依赖包: npm安装: npm install --save-dev babel-core babel-loader babel-preset- ...
- ffmpeg h264转h265
ffmpeg -i d:\soft\720p.mp4 -c:v libx265 -b:v 5000k d:\soft\myvideo.mp4 这里码率是5000k,编码是h265 h265的解码貌似用 ...
- U3D shaderlab 相关指令开关
Subshader { [Tags] [CommonState] Passdef [Passdef ...] }Tags分为SubShader Tags和Pass Tags,Tags放在SubShad ...
- 洛谷P3327 [SDOI2015]约数个数和(莫比乌斯反演)
传送门 公式太长了……我就直接抄一下这位大佬好了……实在懒得打了 首先据说$d(ij)$有个性质$$d(ij)=\sum_{x|i}\sum_{y|j}[gcd(x,y)=1]$$ 我们所求的答案为$ ...
- HTML5新标签介绍
一.Datalist 标签 <input list="browsers"> <datalist id="browsers"> < ...
- IOS在滚动的时候fixed消失
前段时间,除了apple发布了新的硬件之外,同步还发布了新的操作系统,IOS11,当大家都将注意力聚焦在那个奇怪的刘海该如何适配的时候,笔者的项目在适配IOS11却出现了其他的问题. 众所周知,I ...