SonarQube安装文档
1.SonarQube
1.1 SonarQube介绍
SonarQube是管理代码质量一个开放平台,可以快速的定位代码中潜在的或者明显的错误。
SonarQube是否可以使用自定义规则由开发人员的开发语言所决定,详见
https://docs.sonarqube.org/display/DEV/Adding+Coding+Rules
1.2 SonarQube分析C#
分析C#项目的步骤
分析.NET解决方案可以在命令行,Jenkins或TFS / VSO中完成。这是一个简单快速的入门示例。有关详细信息,请参阅: 使用SonarQube扫描仪分析MSBuild 或参考GitHub上的示例项目。
- 安装SonarQube服务器( 有关详细信息,请参阅 安装和升级)
- 安装SonarScanner for MSBuild并确保您可以从拥有源代码的目录中调用SonarScanner.MSBuild.exe
- 安装SonarC#( 有关详细信息,请参阅 安装插件)。默认情况下,SonarC#与SonarQube一起提供。
- 通过从项目的根目录执行以下命令来运行分析:
|
SonarScanner.MSBuild.exe begin /k:"org.sonarqube:sonar-scanner-msbuild" /n:"Project Name" /v:"1.0"<font></font> MSBuild.exe /t:Rebuild<font></font> SonarScanner.MSBuild.exe end |
按照分析结尾处提供的链接,在SonarQube UI中浏览项目的质量。
2. 安装
2.1 JDK
2.1.1 JDK下载以及安装
安装jdk1.8版本或者更高版本。
http://www.oracle.com/technetwork/java/javase/downloads/java-se-jdk-7-download-432154.html
2.1.2 JDK环境变量配置

计算机属性》高级系统设置》高级》环境变量》系统变量,依次找到上图中的界面。
添加服务器环境变量JAVA_HOME, 内容为Java的安装目录。例如我这里的安装目录为C:\Program Files\Java\jdk-12
在服务器环境变量Path中添加Java bin的目录,例如C:\Program Files\Java\jdk-12\bin
最后在dos窗口输入java -version,回车显示如下信息,即表示jdk已经安装成功。

2.2 SonarQube
2.2.1 SonarQube下载以及安装
下载地址:https://www.sonarqube.org/downloads/
- 下载好sonarqube后,解压打开bin目录,启动相应OS目录下的StartSonar。如本文演示使用的是win的64位系统,则打开
D:\sonar\sonarqube-6.3\sonarqube-6.3\bin\windows-x86-64\StartSonar.bat
- 启动浏览器,访问http://localhost:9000,如出现下图则表示安装成功。
2.2.2 SonarQube数据库配置
sonarqube使用的数据库类型可根据实际情况进行配置。下面以sqlserver为例:
- 创建名为sonars的数据库
- 为数据库创建特定的访问账号以及密码,此账号需要有可读可写的权限。如果不想创建特定的用户,使用sa账户也是可以的。使用Microsoft SQL Server时,数据库的排序规则必须为“大小写敏感”(CS)和“重音敏感”(AS),执行如下命令alter database sonar collate Chinese_PRC_CS_AS
- 修改sonar配置文件
在D:\工作软件\sonarqube-7.7\conf\sonar.properties
打开写入以下文本:
sonar.jdbc.username=sa
sonar.jdbc.password=123456
sonar.jdbc.url=jdbc:sqlserver://192.168.58.128;databaseName=sonar;SelectMethod=Cursor;instance=sqlexpress
sonar.login=admin
sonar.password=admin
2.2.3 Sonar-Scanner下载以及安装
下载地址:
2.2.4 Sonar-Scanner数据库配置
1.打开D:\sonar\sonar-scanner-2.5\conf\sonar-runner.properties文件
写入如下文本:
sonar.host.url=http://localhost:9000
sonar.jdbc.url=jdbc:sqlserver://192.168.58.128;databaseName=sonar;SelectMethod=Cursor;instance=sqlexpress
sonar.jdbc.username=sonar
sonar.jdbc.password=123456
2.2.5 环境变量配置
1.新建变量,name=SONAR_RUNNER_HOME。value=D:\sonar\sonar-scanner-2.8
2.打开path,输入%SONAR_RUNNER_HOME%\bin;
3.在都是窗口输入命令:sonar-runner -version,出现以下信息,则表示环境变量设置成功。

2.3 SonarQube Scanner for MSBuild
2.3.1 SonarQube Scanner for MSBuild下载
下载地址:https://github.com/SonarSource/sonar-scanner-msbuild/releases
注意:红色框内的.NetFramework版本的代码分析仪,蓝色框内的.NetCore版本的代码分析仪

下载下来后,解压至合适的磁盘目录即可。
2.3.2 环境变量配置
1.新建变量,name=SONAR_RUNNER_MSBUILD_HOME。value=D:\工作软件\sonar-scanner-2.8-MSbulid
2.打开path,输入%SONAR_RUNNER_MSBUILD_HOME%;
2.3.3 修改配置文件
打开D:\工作软件\sonar-scanner-2.8-MSbulid\SonarQube.Analysis.xml,
要修改的地方只是关于sonarQube服务器的一些配置,关于服务器URL、USER、PASSWORD等
注意,这里的参数User/PassWord是登陆sonarQube平台的用户名和密码,请不要与sonarQube的数据库的登陆用户名和密码搞混淆。

2.3.4 运行步骤
1.打开源代码文件夹,例如”F:\test\ArasCheckItem\ArasCheckItem“,在当前的路径打开cmd(按住Shift键并鼠标右键,点击“在此处打开powershell窗口”),或者打开cmd窗口,并通过命令进入至该源码根目录(sln所在的目录)
2.在打开的dos窗口中执行命令:
MSBuild.SonarQube.Runner.exe begin /k:"TestProject" /n:"MyTestProject" /v:"1.0"
如下图所示,说明执行成功:

参数说明:
/key(简写k):对应projectKey即项目的唯一代码,如两套源代码使用同一个projectKey那扫描的结果将混在一起,所以一个项目需要有一个单独的projectKey
/name(简写n):对应projectName即项目的名称,为项目的一个显示的名称,建立使用完整的项目名称
/version(简写v):对应projectVersion即项目的版本,项目在不同的时期版本也是不一样的,如果方便,可以在sonarQube的服务器中查看到不同的版本代码其中问题的变化
4.运行命令MSBuild.exe,这个MSBuild是系统安装过VS后会存在的一个编译器,以Visual Studio 2017为例,地址是:C:\Program Files (x86)\MSBuild\14.0\Bin
在DOS窗口中执行命令:"C:\Program Files (x86)\MSBuild\14.0\Bin\MSBuild.exe" /t:Rebuild (这里的参数/t如果不指定也是可以扫描出来的)。如果上面的命令不能执行成功,可以按照以下步骤解决问题:(1)在系统变量里面,打开path,输入C:\Program Files (x86)\MSBuild\14.0\Bin\,然后保存;(2)回到dos窗口,输入命令MSBuild.exe /t:Rebuild,然后回车等待命令执行完成即可。出现下图,则表示执行成功:

5.在dos窗输入命令MSBuild.SonarQube.Runner.exe end,回车等待执行结果。出现下图,则表示执行成功:

SonarQube安装文档的更多相关文章
- ORACLE LINUX 6.3 + ORACLE 11.2.0.3 RAC + VBOX安装文档
ORACLE LINUX 6.3 + ORACLE 11.2.0.3 RAC + VBOX安装文档 2015-10-21 12:51 525人阅读 评论(0) 收藏 举报 分类: Oracle RA ...
- Oracle 11g 单实例安装文档
这里介绍在Red Hat Enterprise Linux Server release 5.7 (Tikanga)下安装ORACLE 11.2.0.1.0的过程,本文仅仅是为了写这样安装指导文档而整 ...
- linkedin开源的kafka-monitor安装文档
linkedin开源的kafka-monitor安装文档 linkedin 开源的kafka-monitor的安装使用可以参考官方的readme:流程介绍的已经比较清楚,但是还是有一些地方需要修正.让 ...
- _00024 尼娜抹微笑伊拉克_云计算ClouderaManager以及CHD5.1.0群集部署安装文档V1.0
笔者博文:妳那伊抹微笑 itdog8 地址链接 : http://www.itdog8.com(个人链接) 博客地址:http://blog.csdn.net/u012185296 博文标题:_000 ...
- oracle database 12c R1 安装文档
INSTALLORACLE DATABASE 12C 完整的安装文档下载地址: http://download.csdn.net/detail/royjj/5665869 OS:ORALCE LINU ...
- HAProxy安装文档
HAProxy安装文档 [toc][TOC] 一.环境说明 系统环境:CentOS Linux release 7.2.1511 (Core) 系统内核:3.10.0-327.el7.x86_64 软 ...
- Oracle 12c RAC 静默安装文档
参考文档: https://docs.oracle.com/en/database/oracle/oracle-database/12.2/cwlin/index.html https://docs. ...
- Oracle 12c RAC 安装文档
参考文档: https://docs.oracle.com/en/database/oracle/oracle-database/12.2/cwlin/index.html https://docs. ...
- Azkaban使用安装文档
Azkaban使用安装文档 Azkaban简介 Azkaban的是什么 Azkaban是由Linkedin公司推出的一个批量工作流任务调度器,用于在一个工作流内以一个特定的顺序运行一组工作和流程.Az ...
随机推荐
- docker上配置mysql主从复制
1.在docker上启动2台mysql容器:(这里3306为主,3307为从) docker run -d -e MYSQL_ROOT_PASSWORD=123456 -p 3306:3306 - ...
- CITS1401 Computational Thinking with Python
Department of Computer Science and Software EngineeringCITS1401 ComputationalThinking with PythonPro ...
- python基础3 条件判断 if嵌套
if单向判断: stonenumber=6#为宝石数量赋值 if stonenumber>=6: #条件:如果你拥有的宝石数量大于等于6个 print('你拥有了毁灭宇宙的力量') #结果:显示 ...
- 2018-2019-2 《网络对抗技术》Exp0 Kali安装 Week1 20165225
2018-2019-2 <网络对抗技术>Exp0 Kali安装 Week1 20165225 - 上Kali官网选择Kali Linux 64 bit的torrent,用迅雷解压即可 安装 ...
- oracle学习笔记第三天
--DML(Data Manipulation Language)--insert关键字 插入 ---语法1.元祖值式插入(一次插入一条记录)---格式:insert into 表名(列名1,列名2. ...
- Python selenium巧用Javascript脚本注入解决按钮点选问题
前段时间,笔者忙于应付公司组织的雅思考试,白天.晚上但凡有空,笔者都是埋头伏案,啃剑桥雅思(剑4~剑12)的官方模拟题或者做着与雅思考试相关的准备工作,这个过程持续了40余天.最近总算鼓起勇气走进考场 ...
- ESP8266小知识与注意事项
小知识 1. 什么是"512+512".“1024+1024”? 当ESP8266支持FOTA(无线升级)时,会给系统做个备份,当升级失败时,使之不至于死机.所以flash会被分割 ...
- Jvisualvm 添加插件
1.访问地址:https://visualvm.github.io/pluginscenters.html,找到自己JDK版本对应的插件下载地址(我的JDK版本为1.7.0_67): 2.点击该链接进 ...
- Ubuntu 常见的问题及常见软件的安装_ubuntu16.04
1, 在使用 rpm 删除 rpm 包的时候的: rpm -r *** 报错: error reading information on service sfdc3: No such file or ...
- mysql执行update语句受影响行数是0
mybatis连接mysql数据库,发现同一个update执行多次,返回的int值都是1. 我记得同样的update再次执行时 受影响行数是0. 后来发现,我之前一直用的SQLyog是这样子的. 原来 ...