SonarQube代码质量管理平台安装与配置

1.安装说明

PS:为什么要有安装说明?本人在网上找资料的时候发现很多教程是没有交代清楚安装环境的。所以,不清楚他们的教程是否适合我的环境。明确『安装说明』方便网友了解我的配置环境,便于大家深入理解此教程。

虚拟机:VmWare workstation 12

操作用户:root

系统环境:centos6.5-x86_64(最小化安装)

软件下载目录:/root/opt

================

2.预置条件

1.需要JDK1.6+支持;

2.需要Mysql数据库支持;(虽然SonarQube自带了H2数据库,但是为了方便管理数据推荐使用Mysql数据库)

多说一句:JDK是必须安装的,Mysql数据库并不是必须要安装的,如果公司有Mysql服务器,直接拿来使用就行,江边望海这次就没有安装Mysql直接用公司内网提供的Mysql数据库。

================

3.安装

在安装之前,介绍一下SonarQube和SonarQube Runner之间的关系。

SonarQube是服务器端,它主要有两个功能:1.分析源代码;2.因为它内嵌了Apache模块,所以提供Web端的界面访问。

SonarQube Runner是一个利用SonarQube服务端分析代码的命令行工具,可以把它简单理解为客户端。

下载地址:http://www.sonarqube.org/downloads/

所以,为了安装和调试方便,建议SonarQube和SonarQube Runner都下载。

3.1安装SonarQube

第一步:将下载的http://downloads.sonarsource.com/sonarqube/sonarqube-5.2.zip解压后放到/usr/local目录下。具体步骤如下:

[[email protected] opt]# wget -c http://downloads.sonarsource.com/sonarqube/sonarqube-5.2.zip

[[email protected] opt]# unzip -n sonarqube-5.2.zip -d /usr/local

第二步:配置环境变量

[[email protected] ~]# vi + /etc/profile

添加

SONAR_HOME=/usr/local/sonarqube-5.2

export SONAR_HOME

保存退出并使配置生效

[[email protected] ~]# source /etc/profile

第三步:配置sonar.properties

[[email protected] ~]# vi /usr/local/sonarqube-5.2/conf/sonar.properties

打开后,找到

sonar.host.url=http://localhost:80

sonar.jdbc.username=sonar

sonar.jdbc.password=sonar

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

sonar.web.host=0.0.0.0

sonar.web.context=

sonar.web.port=80

PS:SonarQube默认监听9000端口。由于我这个虚拟机打算专门给Sonar使用。所以,修改成了80.sonar.jdbc.url中的连接地址也修改成了内网中Mysql服务器的地址。

第四步:启动服务

[[email protected] ~]# cd /usr/local/sonarqube-5.2/bin/linux-x86-64

[[email protected] ~]# ./sonar.sh start

另外,启动/停止/重启命令如下: 
#./sonar.sh start   启动服务 
#./sonar.sh stop    停止服务 
#./sonar.sh restart 重启服务

第四步:访问SonarQube Web管理界面。如果能够看到这个界面证明SonarQube安装成功啦。

3.2安装SonarQube Runner

第一步:将下载的http://repo1.maven.org/maven2/org/codehaus/sonar/runner/sonar-runner-dist/2.4/sonar-runner-dist-2.4.zip解压后放到/usr/local目录下。具体步骤如下:

[[email protected] opt]# wget -c http://repo1.maven.org/maven2/org/codehaus/sonar/runner/sonar-runner-dist/2.4/sonar-runner-dist-2.4.zip

[[email protected] opt]# unzip -n sonar-runner-dist-2.4.zip
-d /usr/local

第二步:配置环境变量

[[email protected] ~]# vi + /etc/profile

添加

SONAR_RUNNER_HOME=/usr/local/sonar-runner-2.4/

PATH=.:$SONAR_RUNNER_HOME/bin

export SONAR_RUNNER_HOME

#包含sonar和sonar-runner的环境变量设置

export SONAR_HOME=/usr/local/sonarqube-5.2

export SONAR_RUNNER_HOME=/usr/local/sonar-runner-2.4
export

PATH=$PATH:$SONAR_HOME/bin:$SONAR_RUNNER_HOME/bin

保存并退出

[[email protected] ~]# source /etc/profile

第三步:配置sonar-runner.properties

[[email protected] conf]# vi /usr/local/sonar-runner-2.4/conf/sonar-runner.properties

找到

sonar.host.url=http://localhost:80

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

sonar.jdbc.username=sonar

sonar.jdbc.password=sonar

sonar.login=admin

sonar.password=admin

将前面的#去掉

PS:刚才我们已经看到SonarQube已经可以访问了,所以就将sonar.host.url改成了实际的访问地址。

第四步:运行sonar-runner分析源代码

Sonar官方已经提供了非常全的代码样例便于新手入门用。

下载地址:https://github.com/SonarSource/sonar-examples/archive/master.zip

下载后使用unzip解压。进入php执行sonar-runner命令即可。操作命令如下:

[[email protected] opt]# wget -c
https://github.com/SonarSource/sonar-examples/archive/master.zip

[[email protected] opt]# unzip master.zip

[[email protected] opt]# cd
sonar-examples-master/projects/languages/php/php-sonar-runner

[[email protected] php-sonar-runner]# sonar-runner

如果能够看到下面的输出信息,证明你的SonarQube Runner安装并配置正确啦。

INFO:
------------------------------------------------------------------------

INFO: EXECUTION SUCCESS

INFO:
------------------------------------------------------------------------

Total time: 2:59.167s

Final Memory: 17M/204M

INFO:
------------------------------------------------------------------------

第五步:看看SonarQube的Web界面,是否已经可以看到分析的结果啦。

SonarQube默认是没有安装中文语言包的。可以看到我的截图显示的是中文,因为我安装了中文语言包。如何安装语言包呢。进入SonarQube插件目录,下载语言包即可。步骤如下:

[[email protected] ~]# cd
/usr/local/sonarqube-5.1.1/extensions/plugins

[[email protected] plugins]# wget -c
http://repo1.maven.org/maven2/org/codehaus/sonar-plugins/l10n/sonar-l10n-zh-plugin/1.8/sonar-l10n-zh-plugin-1.8.jar

PS:最新版本的语言包是sonar-l10n-zh-plugin-1.8.jar。

这是中文语言包的源码地址:https://github.com/SonarCommunity/sonar-l10n-zh

如果大家有兴趣可以和老外一起来维护这个源码,如果想体验最新的源码直接下载下来,打包成jar就可以啦

================

4.配置时踩的那些坑

Sonar是一个非常不错的代码分析工具。但是网上很多教程讲的都是Jenkins+Sonar的配置。如果按照网上的教程去做,你会崩溃死的.为什么?原因如下:

1.网上很多教程的Jenkins+Sonar是基于对Java源代码进行分析的。所以,如果做php代码分析,有一个非常重要的步骤是装php插件。而如果将Jenkins+Sonar合在一起配置,坑很多,填到你崩溃为止;

2.Jenkins是一款自动化构建的工具,如果是第一次用,坑也非常多。

抛开Jenkins不谈,直接用Sonnar就可以对源代码进行质量分析。所以,你需要在Centos下先把Sonnar跑通,让它能在命令行下分析源代码。确定这一步没有问题啦,再跟Jenkins做持续集成。

我就是一开始Jenkins+Sonar一起配置,忙了半天,还是配置不好。不是这出问题,就是那里出问题。

================

5.SonarQube可以分析的语言

SonarQube可以分析当下最常用、流行的语言。如:Ruby,Python,Php,Css,Javascript,Java,Go,Web,C#。支持20多种语言。SonarQube安装成功后默认只能分析Java,如果想让它分析其他语言需要安装插件。

支持分析编程语言插件地址:

http://docs.sonarqube.org/display/PLUG/Plugin+Library

如果你是做Web开发的,可以选择安装Php,Css,Javascript,Web这四款就行啦。直接进入到SonarQube的Plugin目录下载,成功后重启SonarQube即可。

例如:安装Php分析插件

[[email protected] ~]# cd
/usr/local/sonarqube-5.1.1/extensions/plugins

[[email protected] plugins]# wget -c
http://downloads.sonarsource.com/plugins/org/codehaus/sonar-plugins/php/sonar-php-plugin/2.6/sonar-php-plugin-2.6.jar

================

6.参考链接

http://blog.csdn.net/hunterno4/article/details/11687269

http://wenku.baidu.com/view/a5c2a3357375a417876f8f09.html

http://my.oschina.net/zj0303/blog/301474

http://www.cnblogs.com/gao241/p/3190701.html

备注:

汉化包sonar-l10n-zh-plugin-1.6.jar放在下面这个目录

/usr/local/sonarqube-5.2/extensions/plugins

然后重启sonar才能生效

cd /usr/local/sonarqube-5.2/bin/linux-x86-64

./sonar.sh 
start

时间: 2024-11-12 02:13:25

SonarQube代码质量管理平台安装与配置的相关文章

SonarQube代码质量管理平台安装与使用--转载

原文:http://blog.csdn.net/hunterno4/article/details/11687269 Sonar简介 Sonar是一个用于代码质量管理的开源平台,用于管理源代码的质量,可以从七个维度检测代码质量 通过插件形式,可以支持包括java,C#,C/C++,PL/SQL,Cobol,JavaScrip,Groovy等等二十几种编程语言的代码质量管理与检测 sonarQube能带来什么? Developers' Seven Deadly Sins1.糟糕的复杂度分布  文件

SonarQube代码质量管理平台安装与使用

Sonar简介 Sonar是一个用于代码质量管理的开源平台,用于管理源代码的质量,可以从七个维度检测代码质量 通过插件形式,可以支持包括java,C#,C/C++,PL/SQL,Cobol,JavaScrip,Groovy等等二十几种编程语言的代码质量管理与检测 sonarQube能带来什么? Developers' Seven Deadly Sins1.糟糕的复杂度分布  文件.类.方法等,如果复杂度过高将难以改变,这会使得开发人员难以理解它们, 且如果没有自动化的单元测试,对于程序中的任何组

SonarQube代码质量管理平台安装

SonarQube是管理代码质量一个开源平台,可以快速的定位代码中潜在的或者明显的错误. SonarQube安装 1.环境准备 (1)sonarQube 下载地址https://www.sonarqube.org/downloads/ 注:官网显示目前最新版本是6.2,但是实在是下载不下来,迫于无奈选择了5.6.4. (2)sonarQube Scanners 下载地址http://docs.sonarqube.org/display/SCAN/Analyzing+Source+Code (2)

SonarQube代码质量管理平台比较好的搭建和使用资料

http://www.voidcn.com/blog/lidujun1028/article/p-3831235.html Sonar (SonarQube)是一个开源平台,用于管理源代码的质量.Sonar 不只是一个质量数据报告工具,更是代码质量管理平台.支持的语言包括:Java.PHP.C#.C.Cobol.PL/SQL.Flex 等. 主要特点: 代码覆盖:通过单元测试,将会显示哪行代码被选中 改善编码规则 搜寻编码规则:按照名字,插件,激活级别和类别进行查询 项目搜寻:按照项目的名字进行

SonarQube代码质量管理平台的安装与配置

一.SonarQube的介绍 SonarQube是一个管理代码质量的开放平台. 可以从七个维度检测代码质量(为什么要用SonarQube): (1)  复杂度分布(complexity): :代码复杂度过高将难以理解.难以维护 (2)  重复代码(duplications): :程序中包含大量复制粘贴的代码是质量低下的表现 (3)  单元测试(unit tests): :统计并展示单元测试覆盖率 (4)  编码规范(coding rules) :通过Findbugs,PMD,CheckStyle

持续集成篇SonarQube 代码质量管理平台的安装

持续集成篇 SonarQube 代码质量管理平台的安装 -------------------------------- 1.SonarQube的介绍 SonarQube是一个管理代码质量的开放平台. 可以从七个维度检测代码质量(为什么要用SonarQube): (1) 复杂度分布(complexity):代码复杂度过高将难以理解.难以维护 (2) 重复代码(duplications):程序中包含大量复制粘贴的代码是质量低下的表现 (3) 单元测试(unit tests):统计并展示单元测试覆盖

linux学习:持续集成篇--sonarqube代码质量管理平台的介绍与安装-04

1.SonarQube的介绍 官网:https://www.sonarqube.org/ SonarQube是一个管理代码质量的开放平台.  1.1 可以从七个维度检测代码质量(为什么要用SonarQube) (1)复杂度分布(complexity):代码复杂度过高将难以理解.难以维护 (2)重复代码(duplications):程序中包含大量复制粘贴的代码是质量低下的表现 (3)单元测试(unit tests):统计并展示单元测试覆盖率 (4)编码规范(coding rules):通过Find

SonarQube代码质量管理平台的配置与使用

SonarQube的配置(前提,先用admin用户登录) 1.安装中文汉化包: Setting >> Update Center >> AvailablePlugins >> LOCALIZATION >> Chinese Pack >> Install 安装完汉化包之后需要重启SonarQube才能生效(重启前可顺便把CheckStyle.PMD等插件安装一下) # /root/sonarqube/bin/linux-x86-64/sonar.

安装sonarQube代码质量管理平台分析PHP代码

只是说说遇到的坑吧, 第一点:不同的PHP版本,需要安装不同的sonar,最新的sonar版本,只适用于高版本的php: 第二点,分析php代码的扩展同样如此,需要用到对应版本的php代码分析扩展: 第三点,在增加php项目,开始分析之后,sonar需要操作数据库,并分析代码,可能会大量消耗cpu和读取数据库,造成机器负载飙升,同时,分析代码可能需要很长的时间,在此期间重启sonar,停止sonar,可能会导致开启失败,内存溢出报错,这个要多等一段时间,根据机器性能不等,我的是在半个 小时左右.