持续集成之代码质量管理-Sonar

原文:http://blog.****.net/abcdocker/article/details/53840582

Sonar介绍

  Sonar 是一个用于代码质量管理的开放平台。通过插件机制,Sonar 可以集成不同的测试工具,代码分析工具,以及持续集成工具。与持续集成工具(例如 Hudson/Jenkins 等)不同,Sonar 并不是简单地把不同的代码检查工具结果(例如 FindBugs,PMD 等)直接显示在 Web 页面上,而是通过不同的插件对这些结果进行再加工处理,通过量化的方式度量代码质量的变化,从而可以方便地对不同规模和种类的工程进行代码质量管理。 
  在对其他工具的支持方面,Sonar 不仅提供了对 IDE 的支持,可以在 Eclipse和 IntelliJ IDEA 这些工具里联机查看结果;同时 Sonar 还对大量的持续集成工具提供了接口支持,可以很方便地在持续集成中使用 Sonar。 
  此外,Sonar 的插件还可以对 Java 以外的其他编程语言提供支持,对国际化以及报告文档化也有良好的支持。

Sonar部署

  Sonar的相关下载和文档可以在下面的链接中找到:http://www.sonarqube.org/downloads/。需要注意最新版的Sonar需要至少JDK 1.8及以上版本。

 上篇文章我们已经可以成功的使用Git进行拉去,Sonar的功能就是来检查代码是否有BUG。除了检查代码是否有bug还有其他的功能,比如说:你的代码注释率是多少,代码有一些建议,编写语法的建议。所以我们叫质量管理

Sonar还可以给代码打分,并且引用了技术宅的功能(告诉你有很多地方没改)

Sonar部署

[root@linux-node1 ~]# yum install -y java-1.8.0
[root@linux-node1 ~]# cd /usr/local/src
软件包我们通过wget或者下载,rz上传到服务器
#软件包下载:https://sonarsource.bintray.com/Distribution/sonarqube/sonarqube-5.6.zip

[root@linux-node1 src]# unzip sonarqube-5.6.zip
[root@linux-node1 src]# mv sonarqube-5.6 /usr/local/
[root@linux-node1 src]# ln -s /usr/local/sonarqube-5.6/ /usr/local/sonarqube

准备Sonar数据库 
如果没有数据库请执行yum install -y mariadb mariadb-server

[root@linux-node1 ~]# systemctl start mariadb
[root@linux-node1 ~]# systemctl enable mariadb
Created symlink from /etc/systemd/system/multi-user.target.wants/mariadb.service to /usr/lib/systemd/system/mariadb.service.
[root@linux-node1 ~]# mysql_secure_installation
[root@linux-node1 ~]# mysql -uroot -p123456

特别提示: 
持续集成之代码质量管理-Sonar

sonar好像不支持MySQL 5.5,所以如果看日志出现以上error 请安装mysql5.6 或者更高版本 
http://blog.****.net/onothing12345/article/details/49910087

执行sql语句

mysql> CREATE DATABASE sonar CHARACTER SET utf8 COLLATE utf8_general_ci;
mysql> GRANT ALL ON sonar.* TO 'sonar'@'localhost' IDENTIFIED BY 'sonar@pw';
mysql> GRANT ALL ON sonar.* TO 'sonar'@'%' IDENTIFIED BY 'sonar@pw';
mysql> FLUSH PRIVILEGES;

配置Sonar

[root@linux-node1 ~]#  cd /usr/local/sonarqube/conf/
[root@linux-node1 conf]# ls
sonar.properties  wrapper.conf

编写配置文件,修改数据库配置

[root@linux-node1 conf]# vim sonar.properties
#我们只需要去配置文件里面修改数据库的认证即可

 14 sonar.jdbc.username=sonar            #数据库用户
 15 sonar.jdbc.password=sonar@pw     #数据库密码
 23 sonar.jdbc.url=jdbc:mysql://localhost:3306/sonar?useUnicode=true&character    Encoding=utf8&rewriteBatchedStatements=true&useConfigs=maxPerformance

配置Java访问数据库驱动(可选) 
  默认情况Sonar有自带的嵌入的数据库,那么你如果使用类是Oracle数据库,必须手动复制驱动类到${SONAR_HOME}/extensions/jdbc-driver/oracle/目录下,其它支持的数据库默认提供了驱动。其它数据库的配置可以参考官方文档: 
http://docs.sonarqube.org/display/HOME/SonarQube+Platform

启动Sonar 
  你可以在Sonar的配置文件来配置Sonar Web监听的IP地址和端口,默认是9000端口。

[root@linux-node1 conf]# vim sonar.properties
 99 #sonar.web.host=0.0.0.0
106 #sonar.web.port=9000

启动命令如下:

[root@linux-node1 ~]# /usr/local/sonarqube/bin/linux-x86-64/sonar.sh start
Starting SonarQube...
Started SonarQube.

如果有什么问题可以看一下日志[/usr/local/sonarqube/logs/sonar.log]

检查是否有相应的端口

[root@linux-node1 ~]# netstat -lntup
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name
tcp        0      0 127.0.0.1:8080          0.0.0.0:*               LISTEN      2239/unicorn master
tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      505/nginx: master p
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN      569/sshd
tcp        0      0 127.0.0.1:25            0.0.0.0:*               LISTEN      971/master
tcp        0      0 127.0.0.1:43163         0.0.0.0:*               LISTEN      5205/java
tcp        0      0 0.0.0.0:8060            0.0.0.0:*               LISTEN      505/nginx: master p
tcp        0      0 127.0.0.1:32000         0.0.0.0:*               LISTEN      4925/java
tcp        0      0 0.0.0.0:43044           0.0.0.0:*               LISTEN      4952/java
tcp        0      0 0.0.0.0:33350           0.0.0.0:*               LISTEN      5205/java
tcp        0      0 0.0.0.0:9000            0.0.0.0:*               LISTEN      5011/java
tcp        0      0 0.0.0.0:33385           0.0.0.0:*               LISTEN      5011/java
tcp        0      0 127.0.0.1:9001          0.0.0.0:*               LISTEN      4952/java
tcp6       0      0 :::3306                 :::*                    LISTEN      4658/mysqld
tcp6       0      0 :::34993                :::*                    LISTEN      2348/java
tcp6       0      0 :::8081                 :::*                    LISTEN      2348/java
tcp6       0      0 :::22                   :::*                    LISTEN      569/sshd
tcp6       0      0 ::1:25                  ::