Sonar簡介
讓客戶滿意是我們工作的目標(biāo),不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術(shù)通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領(lǐng)域值得信任、有價值的長期合作伙伴,公司提供的服務(wù)項目有:域名申請、網(wǎng)頁空間、營銷軟件、網(wǎng)站建設(shè)、鼓樓網(wǎng)站維護、網(wǎng)站推廣。
Sonar是一個用于代碼質(zhì)量管理的開源平臺,用于管理源代碼的質(zhì)量,可以從七個維度檢測代碼質(zhì)量
通過插件形式,可以支持包括java,C#,C/C++,PL/SQL,Cobol,JavaScrip,Groovy等等二十幾種編程語言的代碼質(zhì)量管理與檢測
sonarQube能帶來什么?
Developers' Seven Deadly Sins
1.糟糕的復(fù)雜度分布
文件、類、方法等,如果復(fù)雜度過高將難以改變,這會使得開發(fā)人員難以理解它們,
且如果沒有自動化的單元測試,對于程序中的任何組件的改變都將可能導(dǎo)致需要全面的回歸測試
7.糟糕的設(shè)計(原文Spaghetti Design,意大利面式設(shè)計)
通過sonar可以找出循環(huán),展示包與包、類與類之間的相互依賴關(guān)系
可以檢測自定義的架構(gòu)規(guī)則
通過sonar可以管理第三方的jar包
可以利用LCOM4檢測單個任務(wù)規(guī)則的應(yīng)用情況
檢測耦合
關(guān)于Spaghetti Design:http://docs.codehaus.org/display/SONAR/Spaghetti+Design
通過sonar可以有效檢測以上在程序開發(fā)過程中的七大問題
SonarQube安裝
預(yù)置條件
1.已安裝Java環(huán)境
2.已安裝有MySQL數(shù)據(jù)庫
軟件下載地址:http://www.sonarqube.org/downloads/
下載SonarQube與SonarQube Runner
中文補丁包下載:http://docs.codehaus.org/display/SONAR/Chinese+Pack
1.數(shù)據(jù)庫配置
進入數(shù)據(jù)庫命令
#mysql -u root -p
mysql> CREATE DATABASE sonar CHARACTER SET utf8 COLLATE utf8_general_ci;
mysql> CREATE USER 'sonar' IDENTIFIED BY 'sonar';
mysql> GRANT ALL ON sonar.* TO 'sonar'@'%' IDENTIFIED BY 'sonar';
mysql> GRANT ALL ON sonar.* TO 'sonar'@'localhost' IDENTIFIED BY 'sonar';
mysql> FLUSH PRIVILEGES;
2.安裝sonar與sonar-runner
將下載的sonar-3.7.zip包解壓至Linux某路徑如/usr/local
將下載的sonar-runner-dist-2.3.zip包解壓某路徑/usr/local
添加SONAR_HOME、SONAR_RUNNER_HOME環(huán)境變量,并將SONAR_RUNNER_HOME加入PATH
修改sonar配置文件
編輯
這里使用mysql,因此取消mysql模塊的注釋
#vi 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
修改sonar-runner的配置文件
切換至sonar-runner的安裝目錄下,修改sonar-runner.properties
根據(jù)實際使用數(shù)據(jù)庫情況取消相應(yīng)注釋
#Configure here general information about the environment, such as SonarQube DB details for example
#No information about specific project should appear here
#----- Default SonarQube server
sonar.host.url=http://localhost:9000
#----- PostgreSQL
#sonar.jdbc.url=jdbc:postgresql://localhost/sonar
#----- MySQL
sonar.jdbc.url=jdbc:mysql://localhost:3306/sonar?useUnicode=true&characterEncoding=utf8
#----- Oracle
#sonar.jdbc.url=jdbc:oracle:thin:@localhost/XE
#----- Microsoft SQLServer
#sonar.jdbc.url=jdbc:jtds:sqlserver://localhost/sonar;SelectMethod=Cursor
#----- Global database settings
sonar.jdbc.username=sonar
sonar.jdbc.password=sonar
#----- Default source code encoding
sonar.sourceEncoding=UTF-8
#----- Security (when 'sonar.forceAuthentication' is set to 'true')
sonar.login=admin
sonar.password=admin
3.添加數(shù)據(jù)庫驅(qū)動
除了Oracle數(shù)據(jù)庫外,其它數(shù)據(jù)庫驅(qū)動都默認(rèn)已經(jīng)提供了,且這些已添加的驅(qū)動是sonar唯一支持的,因此不需要修改
如果是Oracle數(shù)據(jù)庫,需要復(fù)制JDBC驅(qū)動至
4.啟動服務(wù)
目錄切換至sonar的
#./sonar.sh start 啟動服務(wù)
#./sonar.sh stop 停止服務(wù)
#./sonar.sh restart 重啟服務(wù)
至此,sonar就安裝好了
訪問http:\\localhost:9000即可
5.sonar中文補丁包安裝
中文包安裝
安裝中文補丁包可以通過訪問http:\\localhost:9000,打開sonar后,進入更新中心安裝
或者下載中文補丁包后,放到SONARQUBE_HOME/extensions/plugins目錄,然后重啟SonarQube服務(wù)
sonar作為Linux服務(wù)并開機自啟動
新建文件/etc/init.d/sonar,輸入如下內(nèi)容:
#!/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 $*
SonarQube開機自啟動(Ubuntu, 32位):
sudo ln -s $SONAR_HOME/bin/linux-x86-32/sonar.sh /usr/bin/sonar
sudo chmod 755 /etc/init.d/sonar
sudo update-rc.d sonar defaults
SonarQube開機自啟動(RedHat, CentOS, 64位):
sudo ln -s $SONAR_HOME/bin/linux-x86-64/sonar.sh /usr/bin/sonar
sudo chmod 755 /etc/init.d/sonar
sudo chkconfig --add sonar
使用SonarQube Runner分析源碼
預(yù)置條件
已安裝SonarQube Runner且環(huán)境變量已配置,即sonar-runner命令可在任意目錄下執(zhí)行
1.在項目源碼的根目錄下創(chuàng)建sonar-project.properties配置文件
以Android項目為例:
sonar.projectKey=android-sonarqube-runner
sonar.projectName=Simple Android project analyzed with the SonarQube Runner
sonar.projectVersion=1.0
sonar.sources=src
sonar.binaries=bin/classes
sonar.language=java
sonar.sourceEncoding=UTF-8
sonar.profile=Android Lint
注:要使用Android Lint
規(guī)則分析需要先訪問http:\\localhost:9000更新中心添加Android Lint插件,使其可以分析Android Lint規(guī)則
2.執(zhí)行分析
切換到項目源碼根目錄,執(zhí)行命令
# sonar-runner
分析成功后訪問http:\\localhost:9000即可查看分析結(jié)果
不同參數(shù)的意思:
http://docs.codehaus.org/display/SONAR/Analysis+Parameters
不同項目的源碼分析示例下載:
https://github.com/SonarSource/sonar-examples/zipball/master
與IDE關(guān)聯(lián)
最后,當(dāng)然了,得與IDE相關(guān)聯(lián),才能更方便地實時查看
以Eclipse為例,請見:http://docs.sonarqube.org/display/SONAR/SonarQube+in+Eclipse
附:
sonarQube官網(wǎng)地址:http://www.sonarqube.org/
sonarQube官方文檔地址:http://docs.codehaus.org/display/SONAR/Documentation
sonarQube示例地址:http://nemo.sonarqube.org/
網(wǎng)上另兩篇相關(guān)的文章:http://www.cnblogs.com/gao241/p/3190701.html
http://www.myexception.cn/open-source/1307345.html