Jenkins SonarQube SonarQube Scanner
- 針對(duì) Jacoco + Jenkins + SonarQube & SonarQube Scanner 分為四個(gè)部分寫(xiě)的,建議閱讀的順序?yàn)椋?
- Jacoco Code Coverage
- Jenkins + Jacoco 持續(xù)集成代碼覆蓋率
- SonarQube & SonarQube Scanner
- Jenkins + SonarQube & SonarQube Scanner ?
操作步驟
- 第一步:安裝插件,兩種方式
-
Jenkins→系統(tǒng)管理→管理插件→可選插件→??SonarQube Plugin,如下圖所示??Install SonarQube Plugin -
直接下載 SonarQube Plugin,然后進(jìn)入
Jenkins→系統(tǒng)管理→管理插件→高級(jí)→上傳插件,點(diǎn)擊選擇文件找到之前下載的 sonar.hpi,如下圖所示??
Install SonarQube Plugin
然后點(diǎn)擊上傳即可?。?!
Tip:第一種安裝插件的方式有可能會(huì)失敗,那么就選擇第二種安裝方式。還有一種情況,當(dāng) Jenkins 版本與 SonarQube Plugin 版本不匹配時(shí)也會(huì)導(dǎo)致安裝插件失敗。所以建議將 Jenkins 升級(jí)到最新版本
-
第二步:配置
SonarQube,進(jìn)入Jenkins→系統(tǒng)管理→系統(tǒng)設(shè)置→SonarQube serversAdd SonarQube
點(diǎn)擊Add SonarQube會(huì)看到如下圖所示界面??
參數(shù)配置界面
參數(shù)說(shuō)明:
required:
Name:SonarQube
optional:
Server URL:http://IP:9000/
Server version:根據(jù)安裝的 SonarQube 版本自行選擇
Server authentication token:這個(gè)參數(shù)需要在 SonarQube 平臺(tái)上單獨(dú)生成,下面進(jìn)行說(shuō)明
SonarQube account login:登錄 SonarQube 用戶(hù)名
SonarQube account password:登錄 SonarQube 密碼
Database URL:這個(gè)參數(shù)的值,其實(shí)就是 `SonarQube & SonarQube Scanner` 這篇文章,修改 `sonar.properties` 配置中
`sonar.jdbc.url` 的值
Database login:登錄數(shù)據(jù)庫(kù)用戶(hù)名
Database password:登錄數(shù)據(jù)庫(kù)密碼
(剩下的都是可選參數(shù),就不一一列舉了,上面說(shuō)的這些都是最常用的,下面對(duì) Server authentication token 這個(gè)參數(shù)說(shuō)明一下)
`Server authentication token` 生成
1. 登錄 `SonarQube` → `配置` → `權(quán)限` → `選擇用戶(hù)` → `管理員` → 點(diǎn)擊 admin 用戶(hù) `Tokens` 那一列,如圖??

會(huì)看到如下界面??

2. 在`輸入框`中輸入任意字符(英文字母、中文、特殊字符)都可以,然后點(diǎn)擊 `Generate` 按鈕,會(huì)看到如圖所示??

3. 將所得的 `Token` 填入 `Jenkins` 的 `SonarQube servers` 的配置項(xiàng)中,如圖??

`Tip:理論上來(lái)講,只要配置上圖中的 Name 和 Server URL 這兩個(gè)參數(shù)就OK了`
-
第三步:配置
sonar-scanner,進(jìn)入Jenkins→系統(tǒng)管理→Global Tool Configuration→ 找到SonarQube Scanner,如圖??
點(diǎn)擊SonarQube Scanner 安裝...
點(diǎn)擊新增 SonarQube Scanner
如果不想用自動(dòng)安裝這種方式,安裝的話,那就取消勾選,將自行下載的sonar-scanner上傳至服務(wù)器,然后將存放的路徑寫(xiě)入
SONAR_RUNNER_HOME的輸入框,如果所示?? 第四步:在
JOB中配置Execute SonarQube Scanner,進(jìn)入你想要增加SonarQube Scanner靜態(tài)代碼檢測(cè)的項(xiàng)目中,點(diǎn)擊配置→構(gòu)建→ 點(diǎn)擊增加構(gòu)建步驟→ 選擇Execute SonarQube Scanner,如圖??
Tip:
如果是在 Maven 項(xiàng)目中,想要添加 `Execute SonarQube Scanner`
的話,則選擇
Pre Steps → Add pre-build step → Execute SonarQube Scanner
or
Post Steps → Add post-build step → Execute SonarQube Scanner

Select Execute SonarQube Scanner

Execute SonarQube Scanner Plugin
選擇
JDK 并且將 SonarQube & SonarQube Scanner 這篇文章中的 sonar-project.properties 的參數(shù)填入 Analysis properties 中,如圖??

Configuration Scanner
然后點(diǎn)擊
保存,回到 JOB 頁(yè)面,點(diǎn)擊立即構(gòu)建測(cè)試一下,如果成功的話會(huì)看到 SonarQube 的入口,如圖??

Success
點(diǎn)擊圖中的
SonarQube,跳轉(zhuǎn)至 SonarQube 平臺(tái)對(duì)應(yīng)的項(xiàng)目中去,如圖??

SonarQube
至此 Jacoco + Jenkins + SonarQube & SonarQube Scanner環(huán)境如何搭建及兩者之間如何關(guān)聯(lián)的描述已經(jīng)結(jié)束了。歡迎各位看官,及時(shí)糾錯(cuò),如有疑問(wèn),請(qǐng)?jiān)谙路皆u(píng)論,謝謝







