Jenkins集成sonarQube實(shí)現(xiàn)代碼質(zhì)量檢查過程圖解
1.sonarQube的簡介
SonarQube是一款自動化代碼審查工具,用于檢測代碼中的錯誤、漏洞和代碼異味。它可以與你現(xiàn)有的工作流集成,以支持跨項目分支和拉取請求的連續(xù)代碼檢查。
其工作流程如下:

如圖SonarQube由以下4個組件組成:
1.SonarQube Server:
WebServer:供開發(fā)人員,管理人員瀏覽高質(zhì)量的快照并配置SonarQube實(shí)例Search Server:基于Elasticsearch的Search Server從UI進(jìn)行后退搜索(歷史)computeEngine:負(fù)責(zé)處理代碼分析報告并將其保存在SonarQube數(shù)據(jù)庫中
2.SonarQube Database:
SonarQube實(shí)例的配置(安全性、插件設(shè)置等)項目、視圖等的質(zhì)量快照。
3.SonarQube Plugins:服務(wù)器上安裝了多個SonarQube插件,可能包括語言,SCM,集成,身份驗(yàn)證和管理插件
4.SonarScanners:多種sonar掃描組件,在構(gòu)建/持續(xù)集成服務(wù)器上運(yùn)行以分析項目。
關(guān)于sonar的具體介紹可參考其官網(wǎng)。
2.SonarQube的安裝
SonarQube提供了多種安裝方式,本文將使用docker鏡像的安裝方式進(jìn)行演示。
1.拉取sonarQube的docker容器
$> docker pull sonarqube:8.2-community
2.創(chuàng)建docker數(shù)據(jù)卷
#包含數(shù)據(jù)文件,例如嵌入式H2數(shù)據(jù)庫和Elasticsearch索引
$> docker volume create --name sonarqube_data
#包含插件,例如語言分析器
$> docker volume create --name sonarqube_extensions
#包含有關(guān)訪問,Web流程,CE流程和Elasticsearch的SonarQube日志
$> docker volume create --name sonarqube_logs
3.配置本地數(shù)據(jù)庫(示例使用postgresql)
如果使用postgresql的默認(rèn)schema "public",則無需這一步。如果想自定義schema,則執(zhí)行以下命令
ALTER USER mySonarUser SET search_path to <自定義的schema名稱>
4.啟動sonarQube
$> docker run -d --name sonarqube \
-p 9000:9000 \
#以下為給sonarQube的數(shù)據(jù)庫配置,推薦postgresql
-e SONAR_JDBC_URL=jdbc:postgresql://xxxx:5432/postgres \
-e SONAR_JDBC_USERNAME=... \
-e SONAR_JDBC_PASSWORD=... \
-v sonarqube_data:/opt/sonarqube/data \
-v sonarqube_extensions:/opt/sonarqube/extensions \
-v sonarqube_logs:/opt/sonarqube/logs \
<image_name>
本地瀏覽器訪問localhost:9000即可訪問。
3.sonarQube中創(chuàng)建項目步驟
1:新建項目

步驟2:填寫項目信息

步驟3:創(chuàng)建令牌

步驟4:記錄令牌

創(chuàng)建項目完成,并且記錄下令牌,后續(xù)步驟會用到。
4.jenkins配置sonarQube插件1.安裝sonarQube插件
2.添加sonarQube配置
在jenkins>Manage Jenkins>global configuration中配置sonar的信息,如下圖:

name為自定義的名字,serverURL為sonarqube的訪問地址
最后一項token需要添加。點(diǎn)擊添加,如下圖:

類型選擇 Secret text,并將我們在第三步中得到的token填入secret欄,其余欄目自定義。添加完后,回到上一步Server authentication token選擇剛剛添加的token。
5.項目中引入sonarQube
以下為maven單模塊項目示例:
1.引入sonarqube插件:
<!--添加參數(shù),指定projectKey,即在sonar中創(chuàng)建項目時的名稱--> <properties> <sonar.projectKey>sonar-demo</sonar.projectKey> </properties> <!--添加sonarqube插件--> <plugin> <groupId>org.sonarsource.scanner.maven</groupId> <artifactId>sonar-maven-plugin</artifactId> <version>3.6.0.1398</version> </plugin>
2.手動代碼掃描
執(zhí)行以下命令
mvn sonar:sonar \
-Dsonar.projectKey=sonar的項目名稱 \
-Dsonar.host.url=http://sonar的地址 \
-Dsonar.login=第三步記錄的令牌
執(zhí)行完成回到sonarQube界面,可看到掃描記錄及結(jié)果:
6.jenkins
6.jenkins pipeline中集成sonarqube
在jenkinsfile中定義代碼靜態(tài)檢查的stage,如下圖:

上圖中定義了兩個stage,1.代碼靜態(tài)檢查 2.檢查結(jié)果分析
⚠️:檢查結(jié)果分析階段jenkins通過sonarqube的回調(diào)來得知掃描結(jié)果,需要在sonarqube中配置webhook:

webhook域名為jenkins地址域名。
至此,在jenkins pipeline(流水線)中成功集成sonarqube,如下圖:
7.sonarQube
7.sonarQube自定義質(zhì)量閥
1.創(chuàng)建自定義質(zhì)量閥
2.
配置質(zhì)量閥
3.測試
例如當(dāng)閥值過高時,掃描結(jié)果不符合閥值要求,掃描結(jié)果則會失敗。
示例中我們隨便調(diào)整某個條件至當(dāng)前項目無法到達(dá)的值

此時當(dāng)pipeline在運(yùn)行的時候,代碼質(zhì)量檢查就會失敗,因?yàn)闆]有達(dá)到標(biāo)準(zhǔn)。

⚠️:所以,我們在自定義自己項目的閥值的時候要視不同的項目情況而定。
8.總結(jié)
本文介紹了在jenkins多分支流水線中集成sonarQube,從而實(shí)現(xiàn)在持續(xù)集成中代碼質(zhì)量檢查。文章涉及到的某些方面(jenkinsfile,sonarQube詳細(xì)使用等等)沒有詳細(xì)介紹,只是快速帶過了。sonarQube是業(yè)界知名度很高的代碼檢查工具,也是ci/cd中的工具生態(tài)成員。深入探索它,還會發(fā)現(xiàn)更多有用的,有趣的特性。代碼質(zhì)量檢查時代碼質(zhì)量內(nèi)建的一部分,在流水線中集成代碼質(zhì)量檢查可以及時的發(fā)現(xiàn)代碼中存在的問題和缺陷,從而及時修復(fù)問題,防止技術(shù)債務(wù)的堆積(還是那句話,解決問題最好的時機(jī)時問題出現(xiàn)的那一刻),否則當(dāng)問題堆積到一定程度的時候,修復(fù)成本會越來越高。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
springcloud gateway如何配置動態(tài)路由
本文主要介紹了在SpringCloudGateway中配置動態(tài)路由的步驟,包括引入依賴、配置路由源、添加配置中心依賴、配置配置中心、定義路由規(guī)則和刷新配置等內(nèi)容,使路由規(guī)則在配置中心更新時,無需重啟網(wǎng)關(guān)服務(wù)即可動態(tài)應(yīng)用新的路由規(guī)則2024-10-10
Java Stream 流實(shí)現(xiàn)合并操作示例
這篇文章主要介紹了Java Stream 流實(shí)現(xiàn)合并操作,結(jié)合實(shí)例形式詳細(xì)分析了Java Stream 流實(shí)現(xiàn)合并操作原理與相關(guān)注意事項,需要的朋友可以參考下2020-05-05
Mybatis映射文件根標(biāo)簽與子標(biāo)簽示例講解
這篇文章主要介紹了Mybatis映射文件根標(biāo)簽與子標(biāo)簽,本文通過示例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-01-01
Java中生成微信小程序太陽碼的實(shí)現(xiàn)方案
這篇文章主要介紹了Java中生成微信小程序太陽碼的實(shí)現(xiàn)方案,本文講解了如何生成微信小程序太陽碼,通過微信提供的兩種方案都可以實(shí)現(xiàn),在實(shí)際的項目中建議采用第二種方案,需要的朋友可以參考下2022-05-05
Spring MVC 擴(kuò)展和 SSM 框架整合步驟詳解
在前端頁面后后臺交互的過程中,需要一種格式清晰、高效且兩端都可以輕松使用的數(shù)據(jù)格式做交互的媒介,JSON正可以滿足這一需求,下面學(xué)習(xí)使用Spring MVC 框架處理JSON數(shù)據(jù),感興趣的朋友一起看看吧2024-08-08
詳解Java實(shí)現(xiàn)數(shù)據(jù)結(jié)構(gòu)之并查集
并查集這種數(shù)據(jù)結(jié)構(gòu),可能出現(xiàn)的頻率不是那么高,但是還會經(jīng)常性的見到,其理解學(xué)習(xí)起來非常容易,通過本文,一定能夠輕輕松松搞定并查集2021-06-06
基于Flyway實(shí)現(xiàn)簡化Spring Boot項目部署
這篇文章主要介紹了基于Flyway實(shí)現(xiàn)簡化Spring Boot項目部署,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-06-06
Java并發(fā)編程學(xué)習(xí)之ThreadLocal源碼詳析
這篇文章主要給大家介紹了關(guān)于Java并發(fā)編程學(xué)習(xí)之源碼分析ThreadLocal的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-06-06

