【DevOps實踐】5. Jenkins流水線集成SonarQube做代碼質(zhì)量分析

1. 摘要

本文講解使用SonarQube和SonarQube Scanner如何配合做代碼檢查配置攒钳,并完成所有部署實踐铺韧。

2.實踐內(nèi)容

2.1 前置配置

參考《【DevOps實踐】4. Ubuntu下安裝配置代碼檢測工具SonarQube+MySQL》,我們已經(jīng)完成了SonarQube環(huán)境搭建底挫。訪問網(wǎng)址為:https://sonar.artarva.com/犁享。
參考《【DevOps實踐】3. Jenkins流水線搭建golang項目持續(xù)集成環(huán)境》,我們已經(jīng)完成了Jenkins集成環(huán)境搭建再来,并且完成了一個GO項目的流水線下載代碼鹰霍,編譯闻鉴,部署的完整持續(xù)集成流程。訪問網(wǎng)址為:
https://jenkins.artarva.com/
我們接下來要做的是采用SonarQube獨立實現(xiàn)代碼質(zhì)量掃碼茂洒,然后把該功能集成到Jenkins環(huán)境中孟岛。

2.2 使用sonar單獨完成一個GO項目的代碼檢查

配置好sonar的服務(wù)端后,接下來就要使用sonar檢測我們的代碼了督勺,sonar主要是借助客戶端檢測工具來檢測代碼渠羞,所以要使用sonar就必須先在我們本地配置好客戶端檢測工具。
客戶端可以通過IDE插件玷氏、Sonar-Scanner插件堵未、Ant插件和Maven插件方式進(jìn)行掃描分析腋舌。常用的有掃描器有Sonar-Scanner和Sonar-Runner盏触,使用起來都差不多。這里我使用Sonar-Scanner來作為檢測客戶端块饺。

2.2.1 安裝sonar scanner

(1) 安裝
最好用sonar-scanner-2.8版本赞辩,支持jdk1.8,否則其他版本會出錯授艰。

cd /opt
wget https://binaries.sonarsource.com/Distribution/sonar-scanner-cli/sonar-scanner-2.8.zip
unzip sonar-scanner-2.8.zip  # 解壓后辨嗽,目錄名改為sonar-scanner
mv sonar-scanner-2.8 sonar-scanner

(2) 配置sonar qube和sonar scanner的環(huán)境變量
在root賬號下配置sonar用戶的sudo權(quán)限

chmod u+w /etc/sudoers
vim /etc/sudoers

增加sudo授權(quán)

sonar   ALL=(ALL:ALL) ALL

root賬號下,編輯/etc/profile 文件,
增加sonar環(huán)境變量信息和sonar-scanner 環(huán)境變量信息淮腾。

#sonar配置
export SONAR_HOME=/opt/sonar
export PATH=${SONAR_HOME}/bin:${PATH}

#set sonar-scanner environment
export SONAR_SCANNER_HOME=/opt/sonar-scanner
export PATH=${SONAR_SCANNER_HOME}/bin:${PATH}

執(zhí)行source ~/.bash_profile使環(huán)境變量生效糟需。
source命令通常用于重新執(zhí)行剛修改的初始化文件屉佳,使之立即生效,而不必注銷并重新登錄洲押。需要永久生效則需要reboot重啟系統(tǒng)武花。

source ~/.bash_profile

(3)編輯sonar-scanner.properties文件
vim /opt/sonar-scanner/conf/sonar-scanner.properties

#----- Default SonarQube server
sonar.host.url=http://localhost:9000

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

2.2.2 增加工程
(1) 在sonarQube頁面,點擊右上角的+號杈帐,增加一個工程体箕,填寫名稱。

(2) 產(chǎn)生TOKEN
Analyze "training-ip-demo" 2: 80ecdaf54216297c11a536c4ff905973a10d7f3c

(3)根據(jù)提示編輯執(zhí)行配合
選擇預(yù)覽挑童,執(zhí)行的系統(tǒng)環(huán)境累铅,如下所示:



可以獲取運行代碼:

sonar-scanner \
  -Dsonar.projectKey=training-ip-demo \
  -Dsonar.sources=. \
  -Dsonar.host.url=https://sonar.artarva.com \
  -Dsonar.login=80ecdaf54216297c11a536c4ff905973a10d7f3c

(3) 在待掃描的項目根目錄下創(chuàng)建文件 sonar-project.properties,文件內(nèi)容
vim sonar-project.properties,內(nèi)容如下:

# must be unique in a given SonarQube instance
sonar.projectKey=1: e496e00dcc53d285f39a1c1725ba1394c56779ff

# --- optional properties ---
# language
sonar.language=go

# defaults to project key
sonar.projectName=training-ip-demo
# defaults to 'not provided'
#sonar.projectVersion=1.0

# Path is relative to the sonar-project.properties file. Defaults to .
sonar.sources=.
sonar.exclusions=**/*_test.go,**/doc/**,**/docwatermark/**

# test file
sonar.tests=.
sonar.test.inclusions=**/*_test.go


# Encoding of the source code. Default is default system encoding
sonar.sourceEncoding=UTF-8

(4) Linux shell下執(zhí)行掃碼分析工具
執(zhí)行命令:

sonar-scanner \
>   -Dsonar.projectKey=training-ip-demo \
>   -Dsonar.sources=. \
>   -Dsonar.host.url=https://sonar.artarva.com \
>   -Dsonar.login=80ecdaf54216297c11a536c4ff905973a10d7f3c

執(zhí)行成功,可以看到

點擊地址:https://sonar.artarva.com/dashboard?id=training-ip-demo
可以查看掃碼結(jié)果站叼。根據(jù)分析報告處理代碼吧娃兽。

2.3 Jenkins流水線集成SonarQube

2.3.1 SonarQube配置準(zhǔn)備

(1)打開TOKEN授權(quán)開關(guān)
使用Admin賬號登錄Sonar,打開Server authentication token開關(guān)尽楔。
位置:https://sonar.artarva.com/admin/settings 的Administration/Configuration/Security菜單位置换薄。


(2)獲取一個TOKEN
登錄后右上角點擊用戶名稱,選擇我的賬號翔试,進(jìn)入個人賬號設(shè)置
選擇安全頁轻要,在Generate Tokens中輸入一個名稱,如:preproduct-training-ip-demo垦缅,然后點擊Generate冲泥,生成一個token。
位置:右上角的My Account /Security/Tokens
記錄該值壁涎,例如:cb4238366e2fb9b8a89324eef5581cdec439a36d

2.3.2 在Jenkins上配置SonarQube token

在Jenkins上凡恍,打開Credentials,添加一個Global的Credential怔球,選擇Credential類型為Secret text嚼酝。
輸入Secret為上面生成的SonarQube token,例如上面的“cb4238366e2fb9b8a89324eef5581cdec439a36d”
輸入一個有意義的描述竟坛,ID可以自動產(chǎn)生闽巩。

2.3.3 在Jenkins上安裝SonarScanner插件

在Jenkins上安裝SonarScanner插件,參見:
http://redirect.sonarsource.com/plugins/jenkins.html
位置:系統(tǒng)管理/插件管理/ 担汤,安裝成功的截圖涎跨。

2.3.4 在Jenkins上配置SonarQube server

位置:系統(tǒng)管理/系統(tǒng)配置
Name:填寫一個便于記憶的名稱。
Server URL:填寫sonarQube的服務(wù)器地址崭歧,例如https://sonar.artarva.com
Server authentication token:選擇剛才在授權(quán)憑證建立的token隅很。

2.3.5 在Jenkins流水線中使用SonarQube做代碼質(zhì)量檢查

《【DevOps實踐】3. Jenkins流水線搭建golang項目持續(xù)集成環(huán)境》的pipeline腳本的基礎(chǔ)上增加一個步驟。

        stage('2.代碼質(zhì)量檢查') {
            steps {
                sh """
                     /opt/sonar-scanner/bin/sonar-scanner \
                    -Dsonar.projectKey=preproduct-training-ip-demo \
                    -Dsonar.sources=. \
                    -Dsonar.host.url=https://sonar.artarva.com \
                    -Dsonar.login=cb4238366e2fb9b8a89324eef5581cdec439a36d
                """        
            }
        }  

2.3.6 執(zhí)行流水線腳本率碾,獲取結(jié)果


根據(jù)輸出提示叔营,可以查看代碼質(zhì)量檢查結(jié)果屋彪。
【點評】代碼重復(fù)率太高,評分不合格呢绒尊。

https://sonar.artarva.com/dashboard?id=preproduct-training-ip-demo

3.參考

(1)Jenkins 集成 SonarQube Scanner
https://www.cnblogs.com/cjsblog/archive/2019/04/20/10740840.html
【說明】缺少安裝 SonarQube服務(wù)器的說明

(2)GO語言檢查配置
How to run SonarQube for Go code using Jenkins
https://stackoverflow.com/questions/63832311/how-to-run-sonarqube-for-go-code-using-jenkins

https://docs.sonarqube.org/latest/analysis/languages/go/

(3)Jenkins+SonarQube+Gitlab搭建自動化持續(xù)代碼掃描質(zhì)量平臺
https://blog.csdn.net/zuozewei/article/details/84539396
【說明】介紹sonar的作用整體撼班。

(4) SonarQube集成golang檢測
https://blog.csdn.net/baidu_36943075/article/details/90634160

(5)使用Jenkins流水線集成SonarQube做代碼質(zhì)量分析
https://blog.csdn.net/nklinsirui/article/details/90518618

(6)GO項目配置
https://docs.sonarqube.org/latest/analysis/languages/go/

(7) sonarqube SonarGo 搭建和golang代碼檢視的使用教程
http://www.reibang.com/p/95ae320aa46d

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市垒酬,隨后出現(xiàn)的幾起案子砰嘁,更是在濱河造成了極大的恐慌,老刑警劉巖勘究,帶你破解...
    沈念sama閱讀 216,591評論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件矮湘,死亡現(xiàn)場離奇詭異,居然都是意外死亡口糕,警方通過查閱死者的電腦和手機缅阳,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,448評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來景描,“玉大人十办,你說我怎么就攤上這事〕祝” “怎么了向族?”我有些...
    開封第一講書人閱讀 162,823評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長棠绘。 經(jīng)常有香客問我件相,道長,這世上最難降的妖魔是什么氧苍? 我笑而不...
    開封第一講書人閱讀 58,204評論 1 292
  • 正文 為了忘掉前任夜矗,我火速辦了婚禮,結(jié)果婚禮上让虐,老公的妹妹穿的比我還像新娘紊撕。我一直安慰自己,他們只是感情好赡突,可當(dāng)我...
    茶點故事閱讀 67,228評論 6 388
  • 文/花漫 我一把揭開白布对扶。 她就那樣靜靜地躺著,像睡著了一般麸俘。 火紅的嫁衣襯著肌膚如雪辩稽。 梳的紋絲不亂的頭發(fā)上惧笛,一...
    開封第一講書人閱讀 51,190評論 1 299
  • 那天从媚,我揣著相機與錄音,去河邊找鬼患整。 笑死拜效,一個胖子當(dāng)著我的面吹牛喷众,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播紧憾,決...
    沈念sama閱讀 40,078評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼到千,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了赴穗?” 一聲冷哼從身側(cè)響起憔四,我...
    開封第一講書人閱讀 38,923評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎般眉,沒想到半個月后了赵,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,334評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡甸赃,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,550評論 2 333
  • 正文 我和宋清朗相戀三年柿汛,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片埠对。...
    茶點故事閱讀 39,727評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡络断,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出项玛,到底是詐尸還是另有隱情貌笨,我是刑警寧澤,帶...
    沈念sama閱讀 35,428評論 5 343
  • 正文 年R本政府宣布襟沮,位于F島的核電站躁绸,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏臣嚣。R本人自食惡果不足惜净刮,卻給世界環(huán)境...
    茶點故事閱讀 41,022評論 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望硅则。 院中可真熱鬧淹父,春花似錦、人聲如沸怎虫。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,672評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽大审。三九已至蘸际,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間徒扶,已是汗流浹背粮彤。 一陣腳步聲響...
    開封第一講書人閱讀 32,826評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人导坟。 一個月前我還...
    沈念sama閱讀 47,734評論 2 368
  • 正文 我出身青樓屿良,卻偏偏與公主長得像,于是被迫代替她去往敵國和親惫周。 傳聞我的和親對象是個殘疾皇子尘惧,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,619評論 2 354

推薦閱讀更多精彩內(nèi)容