本文共 3258 字,大约阅读时间需要 10 分钟。
http://docs.sonarqube.org/display/SONAR/Documentation/
公司前段时间推动项目代码质量评估,发现Sonar不错,能够集成checkstyle,findbugs,pmd的大部分功能。Sonar支持三种运行方式: Maven集成,Ant集成,Sonar Runner。
到官方网站下载Sonar的压缩包,解压到任意目录
Sonar默认使用嵌入式Derby数据库,如果要迁移到Mysql上,需首先创建一个sonar/sonar的UTF-8的mysql数据库,并授权访问sonar库
mysql> CREATE DATABASE sonar CHARACTER SET utf8 COLLATE utf8_general_ci; mysql> grant all privileges on sonar.\* to 'sonar'@'localhost' identified by 'sonar'; mysql> flush privileges;Properties代码:
#sonar.jdbc.url: jdbc:derby://localhost:1527/sonar;create=true #sonar.jdbc.driver: org.apache.derby.jdbc.ClientDriver #sonar.jdbc.defaultTransactionIsolation: 1 #sonar.jdbc.validationQuery: values(1) sonar.jdbc.url: jdbc:mysql://localhost:3306/sonar?useUnicode=true&characterEncoding=utf8 sonar.jdbc.driver: com.mysql.jdbc.Driver sonar.jdbc.validationQuery: select 1http://www.cnblogs.com/biglaojiang/archive/2013/05/15/3080243.html
1、Sonar介绍
Sonar是一个用于代码质量管理的开源平台,用于管理Java源代码的质量。
通过插件机制,Sonar 可以集成不同的测试工具,代码分析工具,以及持续集成工具。通过不同的插件对这些结果进行再加工处理,通过量化的方式度量代码质量的变化,从而可以方便地对不同规模和种类的工程进行代码质量管理。
同时 Sonar 还对大量的持续集成工具提供了接口支持,可以很方便地在持续集成中使用 Sonar。
此外,Sonar 的插件还可以对 Java 以外的其他编程语言提供支持,对国际化以及报告文档化也有良好的支持。
2、安装、配置Sonar
Sonar的运行需要 JDK 1.5+ , Maven 2.0.9+ 的支持,因此需要系统中安装以上两个软件;从 下载sonar(最新版本3.5.1)zip文件,解压到任意目录,即完成安装.
Sonar有两种启动方式:
第一种:直接启动${SONAR_HOME}/bin下对应系统的脚本即可.
windows环境下,启动${SONAR_HOME}/bin/windows-x86-32/StartSonar.bat, 在浏览器中访问: http://localhost:9000/,界面如下:
由于Sonar自带了Jetty6 的应用服务器环境,所以不需要额外的配置即可使用.Sonar默认的端口是”9000”,默认的上下文路径是”/”,默认的网络接口是”0.0.0.0”;这些参数都可以在${SONAR_HOME}/conf/sonar.properties中修改.
默认的管理员帐号和密码为:admin/admin.
第二种:作为Web项目,部署到Tomcat等应用服务器中.
步骤如下(以tomcat为例):
a. 编辑conf/sonar.properties还原成标准格式(就是不修改端口之类);确保部署到应用服务器时conf/wrapper.conf未被使用过;
b. ${SONAR_HOME}/war目录下执行build-war.bat脚本;将生成的sonar.war部署到应用服务器中; c. 启动Tomcat, 通过 访问.为了避免内存溢出,增加内存堆栈的大小:在Tomcat启动前设置CATALINA_OPTS环境变量:
CATALINA_OPTS=”-Xms1024m -Xmx1024m -Dorg.apache.jasper.runtime.BodyContentImpl.LIMIT_BUFFER=true -XX:MaxPermSize=256m”
3、数据库安装配置及数据库连接配置
Sonar需要一个数据库来存储结果,Apache Derby 是Sonar自带并且默认安装使用的数据库,它能很好的用于Sonar的演示.但在实际项目中推荐使用性能更好更强大的数据库.
Sonar对如下数据库提供支持:MySQL 5.x, Oracle 10g XE, Postgresql, MS SqlServer 2005 等.(以MySQL为例进行介绍):
a. 编辑${SONAR_HOME}/conf/sonar.properties配置数据库:
b. 配置DB驱动包.
如果使用Oracle数据库,必须手动复制驱动类到${SONAR_HOME}/extensions/jdbc-driver/oracle/目录下;其它支持的数据库默认提供了驱动.
经过以上步骤,重启Sonar服务(使用Tomat等外置服务器者,需要重新打war包,重启服务器);会自动创建名为sonar的数据库,帐号和密码分别为sonar、sonar的用户(sonar默认值);通过浏览器访问sonar服务即可.
注:经测试,发现如果不先手动创建sonar用户时,sonar不能正确的执行创建(这与数据库本身的用户权限有关,默认帐号不对,或者权限不够,自然不能创建数据库了)!在此建议先手动创建数据库(sonar)和用户(sonar),同时给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; |
列举了一些常用的配置及默认值.
启动过程中如有报错,可参考我的另一篇博客()
http://www.cnblogs.com/javawebsoa/p/3206504.html
Sonar是一个开源代码质量管理平台。以下是它的主要特点:
从 下载安装文件,解压到任意目录,执行对应32/64的 StartSonar.bat,默认在9000端口启动一个服务
有详细的文档,最快的方法是如下的形式
http://www.cnblogs.com/2018/archive/2011/09/14/2175497.html