溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么進行SonarQube代碼質(zhì)量管理平臺安裝與使用

發(fā)布時間:2021-10-14 15:00:20 來源:億速云 閱讀:91 作者:柒染 欄目:編程語言

今天就跟大家聊聊有關怎么進行SonarQube代碼質(zhì)量管理平臺安裝與使用,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。

Sonar簡介

Sonar是一個用于代碼質(zhì)量管理的開源平臺,用于管理源代碼的質(zhì)量,可以從七個維度檢測代碼質(zhì)量

通過插件形式,可以支持包括java,C#,C/C++,PL/SQL,Cobol,JavaScrip,Groovy等等二十幾種編程語言的代碼質(zhì)量管理與檢測

sonarQube能帶來什么?


Developers' Seven Deadly Sins

1.糟糕的復雜度分布

  文件、類、方法等,如果復雜度過高將難以改變,這會使得開發(fā)人員難以理解它們,

  且如果沒有自動化的單元測試,對于程序中的任何組件的改變都將可能導致需要全面的回歸測試

怎么進行SonarQube代碼質(zhì)量管理平臺安裝與使用

2.重復

  顯然程序中包含大量復制粘貼的代碼是質(zhì)量低下的

  sonar可以展示源碼中重復嚴重的地方

怎么進行SonarQube代碼質(zhì)量管理平臺安裝與使用

3.缺乏單元測試

  sonar可以很方便地統(tǒng)計并展示單元測試覆蓋率

怎么進行SonarQube代碼質(zhì)量管理平臺安裝與使用

4.沒有代碼標準

  sonar可以通過PMD,CheckStyle,Findbugs等等代碼規(guī)則檢測工具規(guī)范代碼編寫

5.沒有足夠的或者過多的注釋

  沒有注釋將使代碼可讀性變差,特別是當不可避免地出現(xiàn)人員變動時,程序的可讀性將大幅下降

  而過多的注釋又會使得開發(fā)人員將精力過多地花費在閱讀注釋上,亦違背初衷

6.潛在的bug

  sonar可以通過PMD,CheckStyle,Findbugs等等代碼規(guī)則檢測工具檢測出潛在的bug

怎么進行SonarQube代碼質(zhì)量管理平臺安裝與使用

7.糟糕的設計(原文Spaghetti Design,意大利面式設計)

  通過sonar可以找出循環(huán),展示包與包、類與類之間的相互依賴關系

  可以檢測自定義的架構(gòu)規(guī)則

  通過sonar可以管理第三方的jar包

  可以利用LCOM4檢測單個任務規(guī)則的應用情況

  檢測耦合


關于Spaghetti Design:http://docs.codehaus.org/display/SONAR/Spaghetti+Design

通過sonar可以有效檢測以上在程序開發(fā)過程中的七大問題

SonarQube安裝


預置條件

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配置文件

編輯<install_directory>/conf/sonar.properties文件,配置數(shù)據(jù)庫設置,默認已經(jīng)提供了各類數(shù)據(jù)庫的支持

這里使用mysql,因此取消mysql模塊的注釋

#vi sonar.properties

[java] view
plaincopy

  1. sonar.jdbc.username:                       sonar  

  2. sonar.jdbc.password:                       sonar  

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


  4. # Optional properties  

  5. sonar.jdbc.driverClassName:                com.mysql.jdbc.Driver  



修改sonar-runner的配置文件
切換至sonar-runner的安裝目錄下,修改sonar-runner.properties
根據(jù)實際使用數(shù)據(jù)庫情況取消相應注釋

[java] view
plaincopy

  1. #Configure here general information about the environment, such as SonarQube DB details for example  

  2. #No information about specific project should appear here  

  3. #----- Default SonarQube server  

  4. sonar.host.url=http://localhost:9000

  5. #----- PostgreSQL  

  6. #sonar.jdbc.url=jdbc:postgresql://localhost/sonar

  7. #----- MySQL  

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

  9. #----- Oracle  

  10. #sonar.jdbc.url=jdbc:oracle:thin:@localhost/XE  

  11. #----- Microsoft SQLServer  

  12. #sonar.jdbc.url=jdbc:jtds:sqlserver://localhost/sonar;SelectMethod=Cursor

  13. #----- Global database settings  

  14. sonar.jdbc.username=sonar  

  15. sonar.jdbc.password=sonar  

  16. #----- Default source code encoding  

  17. sonar.sourceEncoding=UTF-8

  18. #----- Security (when 'sonar.forceAuthentication' is set to 'true')  

  19. sonar.login=admin  

  20. sonar.password=admin  

3.添加數(shù)據(jù)庫驅(qū)動

除了Oracle數(shù)據(jù)庫外,其它數(shù)據(jù)庫驅(qū)動都默認已經(jīng)提供了,且這些已添加的驅(qū)動是sonar唯一支持的,因此不需要修改

如果是Oracle數(shù)據(jù)庫,需要復制JDBC驅(qū)動至<install_directory>/extensions/jdbc-driver/oracle目錄



4.啟動服務

目錄切換至sonar的<install_directory>/bin/linux-x86-64/目錄,啟動服務

#./sonar.sh start   啟動服務

#./sonar.sh stop    停止服務

#./sonar.sh restart 重啟服務


至此,sonar就安裝好了

訪問http:\\localhost:9000即可

5.sonar中文補丁包安裝

中文包安裝

安裝中文補丁包可以通過訪問http:\\localhost:9000,打開sonar后,進入更新中心安裝

或者下載中文補丁包后,放到SONARQUBE_HOME/extensions/plugins目錄,然后重啟SonarQube服務

sonar作為Linux服務并開機自啟動

新建文件/etc/init.d/sonar,輸入如下內(nèi)容:

[java] view
plaincopy

  1. #!/bin/sh  

  2. #  

  3. # rc file for SonarQube  

  4. #  

  5. # chkconfig: 345 96 10

  6. # description: SonarQube system (www.sonarsource.org)  

  7. #  

  8. ### BEGIN INIT INFO  

  9. # Provides: sonar  

  10. # Required-Start: $network  

  11. # Required-Stop: $network  

  12. # Default-Start: 3 4 5

  13. # Default-Stop: 0 1 2 6

  14. # Short-Description: SonarQube system (www.sonarsource.org)  

  15. # Description: SonarQube system (www.sonarsource.org)  

  16. ### END INIT INFO  


  17. /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分析源碼

預置條件

已安裝SonarQube Runner且環(huán)境變量已配置,即sonar-runner命令可在任意目錄下執(zhí)行


1.在項目源碼的根目錄下創(chuàng)建sonar-project.properties配置文件

以android項目為例:

[java] view
plaincopy

  1. sonar.projectKey=android-sonarqube-runner  

  2. sonar.projectName=Simple Android project analyzed with the SonarQube Runner  

  3. sonar.projectVersion=1.0

  4. sonar.sources=src  

  5. sonar.binaries=bin/classes  

  6. sonar.language=java  

  7. sonar.sourceEncoding=UTF-8

  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

看完上述內(nèi)容,你們對怎么進行SonarQube代碼質(zhì)量管理平臺安裝與使用有進一步的了解嗎?如果還想了解更多知識或者相關內(nèi)容,請關注億速云行業(yè)資訊頻道,感謝大家的支持。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權內(nèi)容。

AI