持續集成之代碼質量管理-Sonar

原文:http://blog.csdn.net/abcdocker/article/details/53840582

Sonar介紹

  Sonar 是一個用於代碼質量管理的開放平臺。經過插件機制,Sonar 能夠集成不一樣的測試工具,代碼分析工具,以及持續集成工具。與持續集成工具(例如 Hudson/Jenkins 等)不一樣,Sonar 並非簡單地把不一樣的代碼檢查工具結果(例如 FindBugs,PMD 等)直接顯示在 Web 頁面上,而是經過不一樣的插件對這些結果進行再加工處理,經過量化的方式度量代碼質量的變化,從而能夠方便地對不一樣規模和種類的工程進行代碼質量管理。 
  在對其餘工具的支持方面,Sonar 不只提供了對 IDE 的支持,能夠在 Eclipse和 IntelliJ IDEA 這些工具裏聯機查看結果;同時 Sonar 還對大量的持續集成工具提供了接口支持,能夠很方便地在持續集成中使用 Sonar。 
  此外,Sonar 的插件還能夠對 Java 之外的其餘編程語言提供支持,對國際化以及報告文檔化也有良好的支持。javascript

Sonar部署

  Sonar的相關下載和文檔能夠在下面的連接中找到:http://www.sonarqube.org/downloads/。須要注意最新版的Sonar須要至少JDK 1.8及以上版本。php

 上篇文章咱們已經能夠成功的使用Git進行拉去,Sonar的功能就是來檢查代碼是否有BUG。除了檢查代碼是否有bug還有其餘的功能,好比說:你的代碼註釋率是多少,代碼有一些建議,編寫語法的建議。因此咱們叫質量管理java

Sonar還能夠給代碼打分,而且引用了技術宅的功能(告訴你有不少地方沒改)node

Sonar部署python

[root@linux-node1 ~]# yum install -y java-1.8.0 [root@linux-node1 ~]# cd /usr/local/src 軟件包咱們經過wget或者下載,rz上傳到服務器 #軟件包下載:https://sonarsource.bintray.com/Distribution/sonarqube/sonarqube-5.6.zip [root@linux-node1 src]# unzip sonarqube-5.6.zip [root@linux-node1 src]# mv sonarqube-5.6 /usr/local/ [root@linux-node1 src]# ln -s /usr/local/sonarqube-5.6/ /usr/local/sonarqube

準備Sonar數據庫 
若是沒有數據庫請執行yum install -y mariadb mariadb-servermysql

[root@linux-node1 ~]# systemctl start mariadb [root@linux-node1 ~]# systemctl enable mariadb Created symlink from /etc/systemd/system/multi-user.target.wants/mariadb.service to /usr/lib/systemd/system/mariadb.service. [root@linux-node1 ~]# mysql_secure_installation [root@linux-node1 ~]# mysql -uroot -p123456

特別提示: 
image_1b4i40r9q13m916p9jqke68au39.png-106.4kBlinux

sonar好像不支持MySQL 5.5,因此若是看日誌出現以上error 請安裝mysql5.6 或者更高版本 
http://blog.csdn.net/onothing12345/article/details/49910087nginx

執行sql語句git

mysql> CREATE DATABASE sonar CHARACTER SET utf8 COLLATE utf8_general_ci; mysql> GRANT ALL ON sonar.* TO 'sonar'@'localhost' IDENTIFIED BY 'sonar@pw'; mysql> GRANT ALL ON sonar.* TO 'sonar'@'%' IDENTIFIED BY 'sonar@pw'; mysql> FLUSH PRIVILEGES;

配置Sonargithub

[root@linux-node1 ~]# cd /usr/local/sonarqube/conf/ [root@linux-node1 conf]# ls sonar.properties wrapper.conf

編寫配置文件,修改數據庫配置

[root@linux-node1 conf]# vim sonar.properties #咱們只須要去配置文件裏面修改數據庫的認證便可 14 sonar.jdbc.username=sonar #數據庫用戶 15 sonar.jdbc.password=sonar@pw #數據庫密碼 23 sonar.jdbc.url=jdbc:mysql://localhost:3306/sonar?useUnicode=true&character Encoding=utf8&rewriteBatchedStatements=true&useConfigs=maxPerformance

 

配置Java訪問數據庫驅動(可選) 
  默認狀況Sonar有自帶的嵌入的數據庫,那麼你若是使用類是Oracle數據庫,必須手動複製驅動類到${SONAR_HOME}/extensions/jdbc-driver/oracle/目錄下,其它支持的數據庫默認提供了驅動。其它數據庫的配置能夠參考官方文檔: 
http://docs.sonarqube.org/display/HOME/SonarQube+Platform

啓動Sonar 
  你能夠在Sonar的配置文件來配置Sonar Web監聽的IP地址和端口,默認是9000端口。

[root@linux-node1 conf]# vim sonar.properties 99 #sonar.web.host=0.0.0.0 106 #sonar.web.port=9000

啓動命令以下:

[root@linux-node1 ~]# /usr/local/sonarqube/bin/linux-x86-64/sonar.sh start Starting SonarQube... Started SonarQube.

若是有什麼問題能夠看一下日誌[/usr/local/sonarqube/logs/sonar.log]

檢查是否有相應的端口

[root@linux-node1 ~]# netstat -lntup Active Internet connections (only servers) Proto Recv-Q Send-Q Local Address Foreign Address State PID/Program name tcp 0 0 127.0.0.1:8080 0.0.0.0:* LISTEN 2239/unicorn master tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 505/nginx: master p tcp 0 0 0.0.0.0:22 0.0.0.0:* LISTEN 569/sshd tcp 0 0 127.0.0.1:25 0.0.0.0:* LISTEN 971/master tcp 0 0 127.0.0.1:43163 0.0.0.0:* LISTEN 5205/java tcp 0 0 0.0.0.0:8060 0.0.0.0:* LISTEN 505/nginx: master p tcp 0 0 127.0.0.1:32000 0.0.0.0:* LISTEN 4925/java tcp 0 0 0.0.0.0:43044 0.0.0.0:* LISTEN 4952/java tcp 0 0 0.0.0.0:33350 0.0.0.0:* LISTEN 5205/java tcp 0 0 0.0.0.0:9000 0.0.0.0:* LISTEN 5011/java tcp 0 0 0.0.0.0:33385 0.0.0.0:* LISTEN 5011/java tcp 0 0 127.0.0.1:9001 0.0.0.0:* LISTEN 4952/java tcp6 0 0 :::3306 :::* LISTEN 4658/mysqld tcp6 0 0 :::34993 :::* LISTEN 2348/java tcp6 0 0 :::8081 :::* LISTEN 2348/java tcp6 0 0 :::22 :::* LISTEN 569/sshd tcp6 0 0 ::1:25 :::* LISTEN 971/master udp6 0 0 :::33848 :::* 2348/java udp6 0 0 :::5353 :::* 2348/java

#端口是9000哦!

Web登錄:IP:9000 
image_1b4i4e3gkdp51k4t1poe16ul1ec4m.png-113.5kB

提示: 
sonar跟jenkins相似,也是以插件爲主 
sonar安裝插件有2種方式:第一種將插件下載完存放在sonar的插件目錄,第二種使用web界面來使用安裝 
存放插件路徑[/usr/local/sonarqube/extensions/plugins/]

安裝中文插件 
登錄:用戶名:admin 密碼:admin 
image_1b4i53iocg3i1npe1kfb1u6dti413.png-85.8kB 
image_1b4i53qtans06132qg1go31pmj1g.png-80.5kB 
image_1b4i540lu22s1rmr1j6jf6e1b6u1t.png-48.2kB 
image_1b4i546qf3mjfnk1i7b1rloo642a.png-51.5kB 
須要重啓纔會生效

生效後以下圖: 
image_1b4i56q1okim5d8l6mh2nflp34.png-109.5kB

咱們在安裝一個PHP語言 
image_1b4i54ot26j61hcme15t213ue2n.png-49.9kB

舒適提示:若是下載不下來咱們直接去github進行下載,由於咱們這個插件都是使用wget進行下載的 
image_1b4i596mfft08f01nu01t1uqkv3h.png-88.9kB 
咱們如今只能使用java的jar包和php,由於咱們只安裝了java和php的語言插件。若是想使用Python的程序,就須要安裝Python的語言插件

Sonar 插件--->語言插件 (分析什麼語言,你就須要安裝什麼語言的插件)

Sonar經過SonarQube Scanner(掃描器)來對代碼進行分析 
官方文檔:http://docs.sonarqube.org/display/SCAN/Analyzing+with+SonarQube+Scanner

下載掃描器插件

[root@linux-node1 ~]# wget https://sonarsource.bintray.com/Distribution/sonar-scanner-cli/sonar-scanner-2.8.zip [root@linux-node1 ~]# unzip sonar-scanner-2.8.zip [root@linux-node1 ~]# mv sonar-scanner-2.8 /usr/local/ [root@linux-node1 ~]# ln -s /usr/local/sonar-scanner-2.8/ /usr/local/sonar-scanner

 

咱們要將掃描器和sonar關聯起來

[root@linux-node1 ~]# cd /usr/local/sonar-scanner [root@linux-node1 sonar-scanner]# ls bin conf lib [root@linux-node1 sonar-scanner]# cd conf/ [root@linux-node1 conf]# ls sonar-scanner.properties [root@linux-node1 conf]# vim sonar-scanner.properties sonar.host.url=http://localhost:9000 #sonar地址 sonar.sourceEncoding=UTF-8 #字符集 sonar.jdbc.username=sonar #數據庫帳號 sonar.jdbc.password=sonar@pw #數據庫密碼 sonar.jdbc.url=jdbc:mysql://localhost:3306/sonar?useUnicode=true&characterEncoding=utf8 #數據庫鏈接地址 #打開註釋便可

咱們如今須要找一個代碼進行分析。

sonar插件提供了一個代碼的庫 
github:https://github.com/SonarSource/sonar-examples 
咱們下載軟件包:https://github.com/SonarSource/sonar-examples/archive/master.zip

解壓

[root@linux-node1 src]# unzip sonar-examples-master.zip [root@linux-node1 php]# cd sonar-examples-master/projects/languages/php [root@linux-node1 php]# cd php-sonar-runner-unit-tests/ [root@linux-node1 php-sonar-runner-unit-tests]# ll total 8 -rw-r--r-- 1 root root 647 Dec 14 09:57 README.md drwxr-xr-x 2 root root 51 Dec 14 09:57 reports -rw-r--r-- 1 root root 346 Dec 14 09:57 sonar-project.properties drwxr-xr-x 3 root root 31 Dec 14 09:57 src drwxr-xr-x 2 root root 25 Dec 14 09:57 tests #這裏就是PHP的目錄

配置文件解釋: 
若是你想讓我掃描,就須要在代碼路徑下放一個配置文件

[root@linux-node1 php-sonar-runner-unit-tests]# cat sonar-project.properties sonar.projectKey=org.sonarqube:php-ut-sq-scanner #Key sonar.projectName=PHP :: PHPUnit :: SonarQube Scanner #這裏的名稱會顯示在一會的web界面上 sonar.projectVersion=1.0 #版本,這裏的版本一會也會顯示在web界面上 sonar.sources=src #軟件包存放路徑 sonar.tests=tests sonar.language=php #語言 sonar.sourceEncoding=UTF-8 #字體 # Reusing PHPUnit reports sonar.php.coverage.reportPath=reports/phpunit.coverage.xml sonar.php.tests.reportPath=reports/phpunit.xml

#也就是說在項目裏面必須有這個配置文件才能夠進行掃描

掃描 
#提示:須要在項目文件裏面進行執行

[root@linux-node1 php-sonar-runner-unit-tests]# /usr/local/sonar-scanner/bin/sonar-scanner
INFO: Scanner configuration file: /usr/local/sonar-scanner/conf/sonar-scanner.properties
INFO: Project root configuration file: /usr/local/src/sonar-examples-master/projects/languages/php/php-sonar-runner-unit-tests/sonar-project.properties
INFO: SonarQube Scanner 2.8
INFO: Java 1.8.0_111 Oracle Corporation (64-bit)
INFO: Linux 3.10.0-514.2.2.el7.x86_64 amd64
INFO: User cache: /root/.sonar/cache
INFO: Load global repositories INFO: Load global repositories (done) | time=211ms WARN: Property 'sonar.jdbc.url' is not supported any more. It will be ignored. There is no longer any DB connection to the SQ database. WARN: Property 'sonar.jdbc.username' is not supported any more. It will be ignored. There is no longer any DB connection to the SQ database. WARN: Property 'sonar.jdbc.password' is not supported any more. It will be ignored. There is no longer any DB connection to the SQ database. INFO: User cache: /root/.sonar/cache INFO: Load plugins index INFO: Load plugins index (done) | time=3ms INFO: Download sonar-csharp-plugin-5.0.jar INFO: Download sonar-java-plugin-3.13.1.jar INFO: Download sonar-l10n-zh-plugin-1.11.jar INFO: Plugin [l10nzh] defines 'l10nen' as base plugin. This metadata can be removed from manifest of l10n plugins since version 5.2. INFO: Download sonar-scm-git-plugin-1.2.jar INFO: Download sonar-php-plugin-2.9.1.1705.jar INFO: Download sonar-scm-svn-plugin-1.3.jar INFO: Download sonar-javascript-plugin-2.11.jar INFO: SonarQube server 5.6 INFO: Default locale: "en_US", source code encoding: "UTF-8" INFO: Process project properties INFO: Load project repositories ................................................. .................................................

提示:咱們什麼都不指定就會在當面目錄下掃描sonar-project.properties文件,根據配置文件進行掃描工做。掃描以後咱們在web界面上就能夠看到代碼的掃描結果

這裏的名字,版本 都是在sonar-project.properties文件中定義的 
image_1b4i615kfc791t2u2261tae11n3u.png-89.7kB 
質量閾幫咱們設定好一個閾值,超過相應的閾值就算有bug 
image_1b4i61htufea1l9n1voe1r8pgqn4b.png-75.4kB

爲了讓jenkins能夠在構建項目的時候執行sonar,因此咱們須要在jenkins上安裝插件 
image_1b4i6426o4sb18mp16ob4vl1evd4o.png-121.8kB

如今就能夠進行配置,讓jenkins和sonar結合在一塊兒。這樣咱們構建項目的時候就會進行代碼檢測

image_1b4i64e6l199910vo1u3d1tsh148k55.png-140.1kB

image_1b4i64kf41vglnbr4m11rl51t3r5i.png-62kB

點擊保存

image_1b4i650bnnp2n7v1idt1f9o6vu5v.png-125.7kB

配置 
image_1b4i65f50euu1beq19ki1bkf13ti6c.png-86.9kB 
編輯咱們的項目,選擇最下放。找到構建 
image_1b4i65rj31qufmou16u417q914hn6p.png-27.2kB 
對PHP文件進行復制

[root@linux-node1 php-sonar-runner-unit-tests]# cat /usr/local/src/sonar-examples-master/projects/languages/php/php-sonar-runner-unit-tests/sonar-project.properties sonar.projectKey=org.sonarqube:php-ut-sq-scanner sonar.projectName=PHP :: PHPUnit :: SonarQube Scanner sonar.projectVersion=1.0 sonar.sources=src sonar.tests=tests sonar.language=php sonar.sourceEncoding=UTF-8 # Reusing PHPUnit reports sonar.php.coverage.reportPath=reports/phpunit.coverage.xml sonar.php.tests.reportPath=reports/phpunit.xml

image_1b4i66hd316vq1i5g11k8v0j1rcq76.png-60.6kB 
Analysis properties 分析的參數

填寫完畢後,咱們點擊保存 
image_1b4i66u061lhp1qkjvk6124a1k497j.png-90.1kB 
咱們選擇當即構建 
image_1b4i678mn1bl4qsf10buddqmvq80.png-93.5kB

提示:此時的SonarQube是沒法點擊的

點擊Console Output能夠查看構建輸出的內容 
image_1b4i67mp06ltar5im11s6thvk8d.png-171.4kB

#提示:只要沒有error就能夠

image_1b4i6c8qj1pjf1c281billo51sgr8q.png-119.1kB 
構建完成後,咱們發現這裏的SonarQube能夠點擊,咱們點擊SonarQube就會連接到192.168.56.11:9000 就是代碼查看器的地址 
image_1b4i6ci8r1bl9124r12ok19kq7mt97.png-86.1kB

如今咱們已經作到了能夠在git上進行拉取代碼。並進行檢測

咱們還能夠配置一個構建失敗發送郵箱: 
image_1b4i6cva0hl4l8amdq1htu9m19k.png-63.5kB 
在咱們項目裏面設置構建後操做,選擇E-mail Notification 
image_1b4i6d6t717evijk1oa6int195fa1.png-40kB 
舒適提示:使用163郵箱發送的通知被163服務器退回了,所以我將設置在jenkins的郵箱改爲了QQ郵箱

QQ:郵箱須要設置以下: 
image_1b4i6doeh28e1nukrg2l6tid8ae.png-47kB

**一、須要開啓POPE3/SMTP服務 
二、在jenkins上配置的密碼咱們須要點擊生成受權碼進行使用**

QQ郵件默認會收到以下提示: 
image_1b4i6efuj187n1ib516gs5rg1n45ar.png-80.9kB 
當再次構件成功時,郵件內容以下: 
image_1b4i6eptgcpb46a1070196t1bmnb8.png-32kB

相關文章
相關標籤/搜索