配置sonar、jenkins进行持续集成和代码审查

本文以CentOS操做系统为例介绍Sonar的安装配置,以及如何与Jenkins进行集成,经过pmd-cpd、checkstyle、findbugs等工具对代码进行持续审查。 html

1、安装配置sonar

一、Sonar介绍

Sonar是一个用于代码质量管理的开源平台,用于管理Java源代码的质 量。经过插件机制,Sonar 能够集成不一样的测试工具,代码分析工具,以及持续集成工具,好比pmd-cpd、checkstyle、 findbugs、Jenkins。经过不一样的插件对这些结果进行再加工处理,经过量化的方式度量代码质量的变化,从而能够方便地对不一样规模和种类的工程 进行代码质量管理。 java

同时 Sonar 还对大量的持续集成工具提供了接口支持,能够很方便地在持续集成中使用 Sonar。 python

此外,Sonar 的插件还能够对 Java 之外的其余编程语言提供支持,对国际化以及报告文档化也有良好的支持。 mysql

二、配置数据库 linux

Apache Derby 是Sonar自带而且默认安装使用的数据库,此外Sonar对以下数据库提供支持:MySQL 5.x, Oracle 10g XE, Postgresql, MS SqlServer等,本文以mysql为例介绍如何配置数据库:  sql

1)建立数据库 数据库

在mysql中执行以下脚本建立数据库及mysql用户 编程

CREATE DATABASE sonarCHARACTER SET utf8COLLATE utf8_general_ci;api

 

CREATE USER 'sonar' IDENTIFIEDBY 'sonar';浏览器

GRANT ALL ON sonar.*TO 'sonar'@'%' IDENTIFIEDBY 'sonar';

GRANT ALL ON sonar.*TO 'sonar'@'localhost' IDENTIFIEDBY 'sonar';

FLUSHPRIVILEGES;

2)编辑${SONAR_HOME}/conf/sonar.properties配置数据库:

复制代码  

sonar.jdbc.username:                       sonar
sonar.jdbc.password:                       sonar
sonar.jdbc.url:                            jdbc:mysql://localhost:3306/sonar?useUnicode=true&characterEncoding=utf8&rewriteBatchedStatements=true

# Optional properties
sonar.jdbc.driverClassName:                com.mysql.jdbc.Driver

 

复制代码  

3)配置DB驱动包

若是使用Oracle数据库,必须手动复制驱动类到${SONAR_HOME}/extensions/jdbc-driver/oracle/目录下。其它支持的数据库默认提供了驱动,http://docs.codehaus.org/display/SONAR/Analysis+Parameters 列举了一些经常使用的配置及默认值.

4)常见错误及解决方法

添加语言包后,启动报错分析:

下载安装 sonar-l10n-zh-plugin-1.4.jar 语言包(http://docs.codehaus.org/display/SONAR/Chinese+Pack),从新打包部署后,后台报错以下:

Error in Sonar.log : 2012.10.25 14:39:15 INFO org.sonar.INFO Register rules [squid/java]...2012.10.25 14:39:15 ERROR o.s.s.p.Platform The following rule (repository: squid) must have a description: Rule[id=<null>,name=<null>,key=ParsingError,configKey=ParsingError,plugin=squid,enabled=true,severity=MAJOR,cardinality=SINGLE]org.sonar.api.utils.SonarException: The following rule (repository: squid) must have a description: Rule[id=<null>,name=<null>,key=ParsingError,configKey=ParsingError,plugin=squid,enabled=true,severity=MAJOR,cardinality=SINGLE]at org.sonar.server.startup.RegisterRules.validateRule(RegisterRules.java:131) ~[classes/:na]at org.sonar.server.startup.RegisterRules.registerRepository(RegisterRules.java:103) ~[classes/:na]at...

(可参考http://jira.codehaus.org/browse/SONAR-3910)

解决方法:将 extensions\plugins\ 目录下的jar包所有删除,从新加入本地语言包后,从新打包部署便可。

三、安装、配置Sonar

Sonar的运行须要 JDK 1.5+ , 从 http://www.sonarqube.org/downloads/ 下载sonar zip文件,本文以3.6版本为例。

建立运行sonar的CentOS帐户sonar,并设置帐户密码:

# useradd sonar # passwd sonar

 

使用sonar帐户登陆CentOS。

Sonar默认集成了jetty容器,能够直接启动提供服务,也能够经过脚本构建为war包,部署在tomcat容器中。

1)直接启动

编辑.bash_profile,添加环境变量SONAR_HOME

$ vi $HOME/.bash_profile

 

修改为以下内容:

PATH=$PATH:$HOME/bin
SONAR_HOME=$HOME/sonar

export PATH SONAR_HOME

 

使环境变量生效

Source $HOME/.bash_profile

 

运行以下命令启动sonar,其它操做系统sonar均提供了启动脚本

$ ${SONAR_HOME}/bin/linux-x86-64/sonar.sh start

 

在浏览器中访问: http://localhost:9000/ ,运行界面以下:

 

Sonar默认的端口是”9000”、默认的上下文路径是”/”、默认的网络接口是”0.0.0.0”,默认的管理员账号和密码为:admin/admin,这些参数均可以在配置文件中修改:

$ vi ${SONAR_HOME}/conf/sonar.properties

 

2)做为Web项目,部署到Tomcat等应用服务器中

a. 确保conf/sonar.properties、conf/wrapper.conf未被修改使用过

b. 执行以下命令生成war包,将生成的sonar.war部署到应用服务器中

$ ${SONAR_HOME}/war/build-war.sh

 

c. 启动Tomcat, 经过 http://localhost:8080/sonar 访问.

Tomcat安装配置参见:CenOS系统中安装Tomcat7并设置为自启动服务 

四、配置为自启动服务

使用root帐户或者开启sudo权限操做。

建立自启动脚本文件/etc/init.d/sonar

# vi /etc/init.d/sonar

 

添加以下内容

复制代码  

#!/bin/sh # # rc file for SonarQube # # chkconfig: 345 96 10 # description: SonarQube system (www.sonarsource.org) # ### BEGIN INIT INFO # Provides: sonar # Required-Start: $network # Required-Stop: $network # Default-Start: 3 4 5 # Default-Stop: 0 1 2 6 # Short-Description: SonarQube system (www.sonarsource.org) # Description: SonarQube system (www.sonarsource.org) ### END INIT INFO /usr/bin/sonar $*

 

复制代码  

添加启动服务

# ln -s $SONAR_HOME/bin/linux-x86-64/sonar.sh /usr/bin/sonar # chmod 755 /etc/init.d/sonar # chkconfig --add sonar

 

五、配置插件

a)插件介绍

Sonar支持多种插件,插件的下载地址为:http://docs.codehaus.org/display/SONAR/Plugin+Library

将下载后的插件上传到${SONAR_HOME}extensions\plugins目录下,从新启动sonar。

sonar默认集成了Java Ecosystem插件,该插件是一组插件的合集

  • Java [sonar-java-plugin]:java源代码解析,计算指标等

  • Squid [sonar-squid-java-plugin]:检查违反Sonar定义规则的代码

  • Checkstyle [sonar-checkstyle-plugin]:使用CheckStyle检查违反统一代码编写风格的代码

  • FindBugs [sonar-findbugs-plugin]:使用FindBugs检查违反规则的缺陷代码

  • PMD [sonar-pmd-plugin]:使用pmd检查违反规则的代码

  • Surefire [sonar-surefire-plugin]:使用Surefire执行单元测试

  • Cobertura [sonar-cobertura-plugin]:使用Cobertura获取代码覆盖率

  • JaCoCo [sonar-jacoco-plugin]:使用JaCOCO获取代码覆盖率

下面列出了一些经常使用的插件:

b)插件配置示例(本段内容来自http://www.ibm.com/developerworks/cn/java/j-lo-sonar/

Sonar 的主要特点是对不一样工具产生的检查结果进行再加工处理,Sonar 还向用户提供了对数据进行个性化处理的方法。

本节以 Technical Debt 插件为例说明如何经过设置参数影响最后的报告结果。首先了解一下这个插件中的“技术债务”的概念,这个概念最先是在 1992 年由 Ward Cunningham 在他的论文“The WyCash Portfolio Management System”中提出的,以后被软件工程界接受并推广,《重构》的做者 Martin Fowler 也在其 网站上对技术债务有所介绍。其实原理能够理解为“出来混迟早要还的”,当前不规范的代码,会对之后产品修改的成本形成影响。

Soanr 的 Technical Debt 插件提供了默认的计算公式,经过对其中的权重参数进行配置,能够适应不一样公司和项目对技术债务的计算。

 

以上的各项数据指标,能够根据本身公司和项目的不一样状况进行设置,如图所示:

例如默认参数下同一个项目的技术债务指标以下:

修改了参数后的结果为:

可见将 Average time to cover complexity of one (in hours) 从 0.2 修改成 0.01 后,Coverage 的权重变小了,从而达到忽略单元测试覆盖率的做用。不一样的公司和项目能够根据须要调整各自的参数,参数的调优和策略不在本文的讨论范围以内。

经过以上的示例能够看出,Sonar 使用不一样类型的图表显示给用户代码质量的结果,而且这些图表不是简单地对单元测试覆盖率或者静态检测工具的结果进行显示,而是根据软件工程理论进行了二次加工后的结果,更加科学和直观。

c)更新中心

以管理员用户登陆Sonar,进入配置->系统,选择更新中心,如图:

其中Available Plugins选项卡提供了能够选择安装的插件,System Updates能够在线更新Sonar。

下载插件须要注意其中有些插件是须要购买才能使用的,其License类型为Commercial。

 

2、与jenkins集成

一、经过Maven进行集成

修改maven的主配置文件(${MAVEN_HOME}/conf/settings.xml文件或者 ~/.m2/settings.xml文件),在其中增长访问Sonar数据库及Sonar服务地址,添加以下配置:

复制代码  

<profile> <id>sonar</id> <properties> <sonar.jdbc.url>jdbc:mysql://localhost:3306/sonar</sonar.jdbc.url> <sonar.jdbc.driver>com.mysql.jdbc.Driver</sonar.jdbc.driver> <sonar.jdbc.username>sonar</sonar.jdbc.username> <sonar.jdbc.password>sonar</sonar.jdbc.password> <sonar.host.url>http://localhost:9000</sonar.host.url> <!-- Sonar服务器访问地址 --> </properties> </profile> <activeProfiles> <activeProfile>sonar</activeProfile> </activeProfiles>

 

复制代码  

此处注意sonar.host.url地址应根据sonar部署状况修改

一样,为了不内存溢出,推荐增长内存堆栈的大小。设置MAVEN_OPTS环境变量:

set MAVEN_OPTS=”-Xmx512m -XX:MaxPermSize=256m”  

使用Sonar

a. 运行Sonar服务器;

b. 经过 mvn sonar:sonar 将代码注入到Sonar中进行分析处理,并将处理结果以XML的形式保存在数据库中;

c. 经过浏览器访问,显示分析结果;

d. 持续运行Maven构建,会迭代显示分析结果;

e. 能够显式指定sonar插件的版本,以下:

复制代码  

<project> <build> <plugins> <plugin> <groupId>org.codehaus.sonar</groupId> <artifactId>sonar-maven-plugin</artifactId> <version>3.5.1</version> </plugin> </plugins> </build> </project>

 

复制代码  

f. 能够显式的将sonar绑定到Maven生命周期中,以下: 

复制代码  

<plugin>   <groupId>org.codehaus.sonar</groupId> <artifactId>sonar-maven-plugin</artifactId> <version>3.5.1</version> <executions> <execution> <id>sonar</id> <phase>site</phase> <goals> <goal>sonar</goal> </goals> </execution> </executions>   </plugin>

 

复制代码  

此时,指定Maven的site声明周期时,则会自动调用sonar.sonar 命令.

二、直接与Jenkins集成

在jenkins的插件管理中选择安装sonar jenkins plugin,该插件可使项目每次构建都调用sonar进行代码度量。

进入配置页面对sonar插件进行配置,以下图:

配置构建项目,增长Post Build Action:

 

应用程序构建时就会自动触发Sonar对代码的检查