一、 前期准备
1、 jdk1.8
2、 yum
3、 mysql5.6及以上版本
二、 SonarQube服务配置
1、 添加sonar服务用的数据库及用户
建库CREATE DATABASE sonar CHARACTER SET utf8 COLLATE utf8_general_ci;
CREATE USER 'sonar' IDENTIFIED BY 'sonar';
GRANT ALL ON sonar.* TO 'sonar'@'%' IDENTIFIED BY 'sonar';
GRANT ALL ON sonar.* TO 'sonar'@'localhost' IDENTIFIED BY 'sonar';
刷新权限FLUSH PRIVILEGES;
Ctrl+c退出mysql后重启mysql:service mysqld restart
2、 虚拟机创建目录,本地上传sonarqube-7.0安装包
mkdir –p /opt/sonar/server/
unzip sonarqube-7.0.zip
rm –rf sonarqube-7.0.zip
3、 配置sonar.properties
vim /xxx/sonarqube-7.0/conf/sonar.properties
第一处添加:sonar.jdbc.username=xxxx
sonar.jdbc.password=xxxx
第二处添加:
sonar.jdbc.url=jdbc:mysql://localhost:3306/sonar?useUnicode=true&characterEncoding=utf8&rewriteBatchedStatements=true&useConfigs=maxPerformance
注意:修改这2处的目的是sonar将前往mysql存储或读取数据,sonar服务器和mysql在一台机子上,故localhost:3306
4、 配置wrapper.conf
vim /xxx/sonarqube-7.0/conf/wrapper.conf
配置wrapper.java.command=/usr/java/jdk1.8.xxx/bin/java (与sonar用户的环境变量文件~/.bash_profile配置相同)
5、 Sonar启动
注意:sonarqube-7.0需要设置普通用户启动,接下来SonarQube服务端的几个步骤都是在新建的sonar用户下操作的。
5.1 linux操作
cd /xxx/sonarqube-7.0/bin&&ll
uname –a (查看本机linux信息)
sh /xxx/sonarqube-7.0/bin/linux-x86-64/sonar.sh start (64位系统启动方式)
注意:启动start,查看服务状态status,重启restart,关闭stop
5.2 浏览器操作
http://虚拟机ip:port
默认账号密码admin
(conf/sonar.properties里sonar.web.context=/sonar,则浏览器地址为:ip:port/sonar;
conf/sonar.properties里sonar.web.context=,则浏览器地址为:ip:port)
6、 SonarQube汉化
在虚拟机上执行命令
cd /xxx/sonarqube-7.0/extensions/plugins
rz (上传sonar-l10-zh-plugin-1.6.jar到此目录)
重启sonar服务器:
sh /xxx/sonarqube-7.0/bin/linux-x86-64/sonar.sh restart
7、 上传插件
官方地址:https://docs.sonarqube.org/display/PLUG/SonarSource+Plugins
执行命令:
cd /xxx/sonarqube-7.0/extensions/plugins
rz (上传xxx.jar到此目录)
三、 SonarQube客户端
官方地址:
https://docs.sonarqube.org/display/PLUG/SonarSource+Plugins/SCAN/Analyzing+with+SonarQube+Scanner
1、 Sonarqube Scanner默认(linux+win)
1.1 linux
1.1 .1 安装SonarQube Scanner包,解压后,vim conf/sonar-scanner.properties,如下配置:
sonar.jdbc.url=jdbc:mysql://localhost:3306/sonar?useUnicode=true&characterEncoding=utf8&rewriteBatchedStatements=true&useConfigs=maxPerformance
sonar.jdbc.username=xxxx
sonar.jdbc.password=xxxx
sonar.sorceEncoding=UTF-8
#----- Default SonarQube server
sonar.host.url=http://Sonarqube服务端所在虚拟机ip:port
sonar.login=xxxx
sonar.password=xxxx
1.1 .2 配置环境变量,vim /etc/profile,如下:
#配置sonar-scanner
export SONAR_RUNNER_HOME=/usr/local/sonar/sonar-scanner-3.3.0.1492-linux
export PATH=$SONAR_RUNNER_HOME/bin:$PATH
1.2 win
详细安装(略)
2、 sonarqube+maven
2.1 pom.xml中加上依赖:
2.2 cmd 进入任一工程,执行命令:mvn clean verify sonar:sonar
3、 sonarqube+Jenkins(重点)
官方地址:/SCAN/Analyzing+with+SonarQube+for+Jenkins
3.1 jenkins部署机为tomcat8
3.2 jenkins配置
1)jenkins系统管理->插件管理->高级设置-手工上传SonarQube for Jenkins 插件
2)jenkins系统管理->系统设置(SonarQube servers)
Server authentication token在SonarQube服务器web界面配置:配置->权限->用户
3)jenkins 系统管理->全局工具配置(jdk+SonarQube Scanner+maven)
Jdk\maven之前就配好了,这就不展开就说明
4)具体需要被扫描的任务里
增加以下两处
构建任务后,在sonarQube服务端可以看到扫描后的结果,如下: