代码质量管理-Sonar

1.Sonar

摘要
Sonar 是一个用于代码质量管理的开放平台。经过插件机制,Sonar 能够集成不一样的测试工具,代码分析工具,以及持续集成工具.
与持续集成工具(例如 Hudson/Jenkins 等)不一样,Sonar 并非简单地把不一样的代码检查工具结果(例如 FindBugs,PMD 等)直接显示在 Web 页面上,而是经过不一样的插件对这些结果进行再加工处理.
经过量化的方式度量代码质量的变化,从而能够方便地对不一样规模和种类的工程进行代码质量管理。

1.1 Sonar介绍

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

1.2 Sonar部署

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

咱们已经能够成功的使用git进行拉去,Sonar的功能就是来检查代码是否有BUG。除了检查代码是否有bug还有其余的功能,好比说:你的代码注释率是多少,代码有一些建议,编写语法的建议。因此咱们叫质量管理

Sonar还能够给代码打分,而且引用了技术宅的功能(告诉你有不少地方没改)
  •  部署安装
[root@jenkins ~]# yum install -y java-1.8.0
[root@jenkins ~]# cd /usr/local/src/
[root@jenkins src]# wget https://sonarsource.bintray.com/Distribution/sonarqube/sonarqube-5.6.zip
[root@jenkins src]# unzip sonarqube-5.6.zip
[root@jenkins src]# mv sonarqube-5.6 /usr/local/
[root@jenkins src]# ln -s /usr/local/sonarqube-5.6/ /usr/local/sonarqube
  • 准备Sonar数据库 
[root@jenkins local]# yum install -y mariadb mariadb-server
[root@jenkins local]# systemctl start mariadb
[root@jenkins local]# systemctl enable mariadb
  • 进入mysql建立库
MariaDB [(none)]> CREATE DATABASE sonar CHARACTER SET utf8 COLLATE utf8_general_ci;
Query OK, 1 row affected (0.00 sec)

MariaDB [(none)]> GRANT ALL ON sonar.* TO 'sonar'@'localhost' IDENTIFIED BY 'sonar@pw';
Query OK, 0 rows affected (0.00 sec)

MariaDB [(none)]> GRANT ALL ON sonar.* TO 'sonar'@'%' IDENTIFIED BY 'sonar@pw';
Query OK, 0 rows affected (0.00 sec)

MariaDB [(none)]> FLUSH PRIVILEGES;
Query OK, 0 rows affected (0.01 sec)
  •  配置sonar
[root@jenkins sonarqube]#  cd /usr/local/sonarqube/conf/
[root@jenkins conf]# ls
sonar.properties  wrapper.conf
[root@jenkins conf]# vim sonar.properties 

 

  1. [root@jenkins conf]# vim sonar.properties
  2. #咱们只须要去配置文件里面修改数据库的认证便可14 sonar.jdbc.username=sonar #数据库用户
  3. 15 sonar.jdbc.password=sonar@pw #数据库密码
  4. 23 sonar.jdbc.url=jdbc:mysql://localhost:3306/sonar?useUnicode=true&characterEncoding=utf8&rewriteBatchedStatements=true&useConfigs=maxPerformance
  5. #你能够在Sonar的配置文件来配置Sonar Web监听的IP地址和端口,默认是9000端口。
  6. [root@jenkins conf]# vim sonar.properties
  7. 99 #sonar.web.host=0.0.0.0
  8. 106 #sonar.web.port=9000
  • 启动sonar
[root@jenkins conf]# /usr/local/sonarqube/bin/linux-x86-64/sonar.sh start
Starting SonarQube...
Started SonarQube.
#若是有什么问题能够看一下日志
[/usr/local/sonarqube/logs/sonar.log]
相关文章
相关标签/搜索