sonarqube+Scanner代码质量管理工具
本文相关描述基于sonarqube 6.2版本。
下载地址:
sonarqube下载网址:https://www.sonarqube.org/downloads/
Scanner下载网址(用于扫描项目代码质量问题): https://docs.sonarqube.org/display/SCAN/Analyzing+with+SonarQube+Scanner
SonarLint下载网址(用于在开发工具里集成sonar代码扫描):http://www.sonarlint.org/
解压地址(即安装):
我本机安装sonarqube地址为:C:/sonar/sonarqube-6.2
sonar插件
sonar插件的jar目录为: C:/sonar/sonarqube-6.2/lib/bundled-plugins,插件jar下载地址举例:
sonar支持指定开发语言代码扫描插件: https://docs.sonarqube.org/display/PLUG/Plugin+Library
sonar支持java的插件:https://docs.sonarqube.org/display/PLUG/SonarJava
sonar支持git的插件: https://docs.sonarqube.org/display/PLUG/Git+Plugin
sonar支持gitHub的插件: https://docs.sonarqube.org/display/PLUG/GitHub+Plugin
启动sonarqube
1) 创建本地新数据库命名为sonar,本机使用的是MySQL5.7
2) 启动之前修改配置文件C:\sonar\sonarqube-6.2\conf\sonar.properties,主要修改sonar数据库连接配置
sonar.jdbc.url=jdbc:mysql://localhost:3306/sonar?useUnicode=true&characterEncoding=utf8&rewriteBatchedStatements=true&useConfigs=maxPerformance
sonar.jdbc.username=root
sonar.jdbc.password=123456
3) 本机是win10系统64位机器,所以启动目录为:C:\sonar\sonarqube-6.2\bin\windows-x86-64\StartSonar.bat
4) 启动成功后,黑色cmd小窗口不关闭。
5) 在浏览器地址栏输入http://localhost:9000/about,正常出现sonar的html页面即为成功。
6) 同时查看mysql数据库sonar,发现已经自动创建出了44张表。
扫描项目代码质量——第一种:基本的命令行方式
1) Scanner本机解压地址为:C:\sonar\sonar-scanner-2.8\
2) 修改配置文件:C:\sonar\sonar-scanner-2.8\conf\sonar-scanner.properties,修改项为:
sonar.host.url=http://localhost:9000
3) 添加环境变量path: C:\sonar\sonar-scanner-2.8\bin,测试是否设置成功,新打开一个cmd窗口,输入命令sonar-scanner -h,如果出现-开头的列表提示有哪些命令可用则表示成功。
4) 在被扫描的项目根目录下新建配置文件:sonar-project.properties,内容如下:
sonar.projectKey=admin:MyProject
sonar.projectName=MyProject
sonar.projectVersion=1.0
sonar.sources=src/main/java
sonar.tests=src/test/java
sonar.java.binaries=classes
sonar.language=java
#Tells SonarQube where the unit tests execution reports are
sonar.junit.reportsPath=reports/junit
#Tells SonarQube where the unit tests code coverage report is
sonar.jacoco.reportPath=reports/jacoco/jacoco-ut.exec
#Tells SonarQube where the integration tests code coverage report is
sonar.jacoco.itReportPath=reports/jacoco/jacoco-it.exec
# Encoding of the source files
sonar.sourceEncoding=UTF-8
INFO: ------------------------------------------------------------------------
INFO: EXECUTION SUCCESS
INFO: ------------------------------------------------------------------------
6) 在浏览器窗口里输入http://localhost:9000,发现被扫描项目数(Projects Analyzed)为1,代表质量扫描成功。
PS: 但是我发现Coverage(代码覆盖率)这一项值是空的!我估计sonar-scanner命令并不包括代码覆盖率的扫描。
扫描项目代码质量——第二种:实现在eclipse里面扫描代码
1) 集成SonarLint到eclipse里面。这里只记录site方式集成,下载plugins和features从网址:http://downloads.sonarsource.com/eclipse/eclipse/,然后将对应的jar包放入eclipse安装目录下的对应文件夹里plugins和features。重启eclipse,Window -> Preferences -> SonarQube表示集成成功。在console视图里,即可看到SonarQube Console下拉选项。
2) 修改maven的settings.xml如示例:https://docs.sonarqube.org/display/SCAN/Analyzing+with+SonarQube+Scanner+for+Maven
3) 修改项目中的pom.xml文件,增加
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<sonar.language>java</sonar.language>
</properties>
PS: 最后我也没搞出来,估计eclipse插件目前并不成熟,因为官网的示例和我真实下载安装的视图和操作都不一样!
扫描项目代码质量——第三种:扫描maven项目
1) 对于maven项目扫描,扫描方式为:打开cmd窗口,到项目存放的pom.xml的目录下(一般也就是项目根目录下),执行命令mvn sonar:sonar。
如果执行不成功,可尝试下面的描述。
Prepare jacoco agent to allow coverage report generation, build the project, and execute the unit tests:
mvn clean org.jacoco:jacoco-maven-plugin:prepare-agent install
To get coverage per tests information, you will need to activate the profile when running the instrumented tests:
mvn clean org.jacoco:jacoco-maven-plugin:prepare-agent install -Pcoverage-per-test
Analyze the project with SonarQube using Maven:
mvn sonar:sonar
2) 在命令行窗口打印出BUILD SUCCESS之后,代表扫描成功。
3) 查看localhost:9000,发现成功生成项目记录,并且Coverage(代码覆盖率)这一项有值。成功!!!

用户管理
1) 必须以管理员用户登录,才可以看见导航栏的Administration。此处可以使用默认管理员admin账户登录(默认密码也是admin)。
2) Administration -> Security -> Users -> Create User
配置项目相关用户权限
配置指定用户可以拥有某个项目的指定权限。
1) Administration -> Projects -> Management
2) 选中某个已存在的项目Actions -> Edit Permissions -> Users -> Search输入框输入用户名三位数以上,在出现的用户上勾选用户相应的项目权限 或者 直接点击Apply Template按钮应用某个已存在的用户权限模版。
sonarqube+Scanner代码质量管理工具的更多相关文章
- SonarQube代码质量管理工具的升级(sonarqube6.2 + sonar-scanner-2.8 + MySQL5.6+)
SonarQube升级注意事项 0. 前提条件 如果之前是使用sonarqube5.2 + sonar-runner-2.4 +MySQL5.5版本或者类似的组合. 安装方法请参照SonarQube代 ...
- SonarQube(代码质量管理)配置与使用
继 Sonarqube(代码质量管理)环境搭建,交大家如何配置与使用Sonarqube 1: 汉化Sonarqube: 找到 Setting --> Update Center --> A ...
- 程序员必备!Sonar代码质量管理工具
Sonar 是一个用于代码质量管理的开放平台.通过插件机制,Sonar 可以集成不同的测试工具,代码分析工具,以及持续集成工具. Sonar 概述 Sonar 是一个用于代码质量管理的开放平台.通过插 ...
- SonarQube代码质量管理工具的安装(Linux)
一.安装配置sonar 1.Sonar介绍 Sonar是一个用于代码质量管理的开源平台,用于管理Java源代码的质量.通过插件机制,Sonar 可以集成不同的测试工具,代码分析工具,以及持续集成工具, ...
- SonarQube代码质量管理工具安装与使用(sonarqube5.1.2 + sonar-runner-dist-2.4 + MySQL5.x)
1. SonarQube安装(sonarqube5.1.2 + sonar-runner-dist-2.4) 1.1 前提条件 1) 已安装Java环境(version:1.7+) 2) 已安装MyS ...
- 代码质量管理工具 sonar 配置
代码检查工具有很多findBugs等等 sonar配置: 1.下载sonar 5.5, 解压,运行 sonarqube-5.5\bin\windows-x86-64\StartSonar.bat , ...
- Sonar代码质量管理工具
最近上线了,Sonar代码扫描工具: 与jenkins集成: 实现自动扫描: 下面来简单聊聊Sonar能解决什么问题: ---------------------- Sonar简介 Sonar是一个用 ...
- SonarQube(代码质量管理)环境搭建
继 Centos6.6安装Subversion版本控制工具(Subversion + Apache + jsvnadmin) 后,搭建代码质量管理环境 IP:10.0.210.112 环境:Cento ...
- 代码质量管理工具——SonarQube
写在前面 SonarQube(简称Sonar)是管理代码质量的开放平台,它可以快速地对代码质量进行分析,并给出合理的解决方案,提高管理效率,保证代码质量. SonarQube的流行,在于以下几点: 开 ...
随机推荐
- 常见的Js
//根据单独的值切换所有复选框 $("input[type='checkbox']").prop("checked", function( i, val ) { ...
- tp框架实现文件上传
public function shangchuan() { $this->display(); } public function upload() { $uplode= new \Think ...
- losbyday Linux下的强大工具之一akw(转),Shell必备
简单使用:awk :对于文件中一行行的独处来执行操作 .awk -F :'{print $1,$4}' :使用‘:’来分割这一行,把这一行的第一第四个域打印出来 . 详细介绍:AWK命令介绍 a ...
- Spark1.3.0安装
之前在用Hadoop写ML算法的时候就隐约感觉Hadoop实在是不适合ML这些比较复杂的算法.记得当时写完kmeans后,发现每个job完成后都需要将结果放在HDFS中,然后下次迭代的时候再从文件中读 ...
- 不停的实例化对象导致OOM
使用axis调用webService,系统运行一段时间后,出现了 OOM,还好日志中 记下了错误信息. Exception in thread "Thread-1301" java ...
- Response.Write() Alert后页面布局改变
根据peter_zhang给出的解决方案,原文URL:http://www.cnblogs.com/starxp/articles/1939032.html 使用Page.ClientScript.R ...
- UDP传输包大小(转)
源:UDP传输包大小 在进行UDP编程的时候,我们最容易想到的问题就是,一次发送多少bytes好? 当然,这个没有唯一答案,相对于不同的系统,不同的要求,其得到的答案是不一样的,我这里仅对 像ICQ一 ...
- APP被苹果APPStore拒绝的各种原因
APP被苹果APPStore拒绝的各种原因 1.程序有重大bug,程序不能启动,或者中途退出.2.绕过苹果的付费渠道,我们之前游戏里的用兑换码兑换金币.3.游戏里有实物奖励的话,一定要说清楚,奖励由本 ...
- Nginx 在configure时的参数
Nginx 使用 Unix 下常用的 './configure && make && make install' 过程来编译安装. configure 脚本确定系统所具 ...
- Memcached源码分析之请求处理(状态机)
作者:Calix 一)上文 在上一篇线程模型的分析中,我们知道,worker线程和主线程都调用了同一个函数,conn_new进行事件监听,并返回conn结构体对象.最终有事件到达时,调用同一个函数ev ...