自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

關(guān)于SonarQube社區(qū)版使用問題及解決方法

開發(fā) 前端
今天我們解決SonarQube社區(qū)版常用的幾個問題,當(dāng)然還有可能還會有很多問題待解決。

[[375327]]

 1 簡介

在大規(guī)模使用SonarQube平臺對代碼進(jìn)行掃描時可能會遇到以下幾個問題

  • SonarQube平臺數(shù)據(jù)問題(開源版本不支持不同分支)
  • SonarQube掃描規(guī)則問題(當(dāng)配置了默認(rèn)規(guī)則后新建項(xiàng)目如何指定新規(guī)則呢?)
  • SonarQube項(xiàng)目授權(quán)問題(新生產(chǎn)的項(xiàng)目如何配置權(quán)限?)

2 解決SonarQube平臺數(shù)據(jù)問題

當(dāng)我們在大規(guī)模使用SonarQube進(jìn)行代碼質(zhì)量檢查的時候,我們需要讓開發(fā)人員每次都能看到當(dāng)前特性分支的掃描分析數(shù)據(jù),以盡快解決有問題的代碼,提高代碼的質(zhì)量。開源版本會帶來一些問題,因?yàn)椴恢С忠粋€項(xiàng)目多分支的形式,所以我們按照特性分支的名稱來生成相對應(yīng)的掃描項(xiàng)目。(會產(chǎn)生很多Sonarqube項(xiàng)目)

例如: 服務(wù)名稱是 demo-abcd-service

之前我們的做法是不區(qū)分分支,在掃描所有分支的時候都會指定同一個sonar項(xiàng)目。這就是導(dǎo)致SonarQube平臺此項(xiàng)目數(shù)據(jù)不穩(wěn)定的根本原因。

現(xiàn)在的做法是: 假如這個項(xiàng)目有F1,F(xiàn)2等特性分支,在每次對其中特性分支構(gòu)建掃描時會配置sonar掃描參數(shù)(projectName)為 “當(dāng)前的服務(wù)名稱_特性分支名稱”,這樣相當(dāng)于每個特性分支都對應(yīng)一個掃描項(xiàng)目,數(shù)據(jù)就不會出現(xiàn)問題了。

雖然解決了數(shù)據(jù)不穩(wěn)定的問題,但又間接的帶來了一些問題。

  • 每個特性分支生成一個項(xiàng)目,假如特性分支被刪除呢?或者分支很多呢?
  • 對于SonarQube管理員來說很難管理,增加了任務(wù)負(fù)擔(dān)。

總結(jié)一下如何解決問題呢?

  • 從長遠(yuǎn)角度來說最直接的方式當(dāng)然是購買開發(fā)版本 。
  • 現(xiàn)在SonarQube已經(jīng)具有多分支插件了,親測可以使用。
  • 變更代碼掃描的模式,比如將每次特性分支掃描的數(shù)據(jù)關(guān)聯(lián)到提交的commit信息中。

總之,最簡單的方式就是付費(fèi)購買開發(fā)版、企業(yè)版。小型團(tuán)隊(duì)也可以使用生成多項(xiàng)目的方式管理。

3 解決SonarQube掃描規(guī)則問題

在搭建好SonarQube平臺后,已經(jīng)配置好了針對每種語言的"Sonar Way"質(zhì)量配置。我們在大規(guī)模使用中,對掃描Java項(xiàng)目的規(guī)則做了一些定制,有一些新增的規(guī)則還有一部分棄用的規(guī)則,總之大部分還都是默認(rèn)自帶的java規(guī)則,配置好規(guī)則后并設(shè)置為默認(rèn)的規(guī)則。其中有幾十個團(tuán)隊(duì)在用默認(rèn)的規(guī)則,后來個別團(tuán)隊(duì)因需求要使用新的JAVA項(xiàng)目質(zhì)量。如何為新建的項(xiàng)目自動配置好對應(yīng)的質(zhì)量呢?

分析

  • SonarQube平臺中的項(xiàng)目不需要單獨(dú)的新建,而是通過Jenkins構(gòu)建過程中生成。
  • 當(dāng)我們需要為項(xiàng)目指定新的質(zhì)量配置的時候,通常在Sonar WebUi中進(jìn)行配置。
  • 無法通過"-Dsonar.xxxx"方式指定每次分支時使用的質(zhì)量名稱。

應(yīng)對

  • 由于SonarQube項(xiàng)目都是通過流水線掃描后生成的,于是在流水線中增加步驟。
  • 每次掃描之前先判斷項(xiàng)目是否存在,然后指定新的質(zhì)量,再執(zhí)行代碼掃描。

實(shí)施主要通過RESTAPI完成

  • 創(chuàng)建項(xiàng)目:api/projects/create
  • 更新質(zhì)量:api/qualityprofiles/add_project
  • 查找項(xiàng)目:api/projects/search

JenkinsFile(ShareLibrary)參考如下:

  1. package com.devops 
  2.  
  3. //Http req  使用Jenkins插件封裝的方法 哈哈哈 
  4. def HttpReq(reqType,reqUrl,reqBody){ 
  5.     result = httpRequest authentication: '我的憑據(jù)的ID'
  6.                 httpMode: reqType,  
  7.                 contentType: "APPLICATION_JSON"
  8.                 consoleLogResponseBody: true
  9.                 ignoreSslErrors: true,  
  10.                 requestBody: reqBody, 
  11.                 //responseHandle: 'NONE',  
  12.                 url: reqUrl 
  13.                 //quiet: true 
  14.      
  15.     return result 
  16.  
  17. //查找項(xiàng)目 
  18. def SearchProject(projectName){ 
  19.     apiUrl = "http://我的sonar服務(wù)器地址/api/projects/search?projects=${projectName}" 
  20.     resultInfo = HttpReq("GET",apiUrl,''
  21.  
  22.     def result = readJSON text: """${resultInfo.content}""" 
  23.      
  24.     if (result["paging"]["total"] == 0 ){ 
  25.         return "false" 
  26.     } else { 
  27.         return result 
  28.     } 
  29.  
  30. //創(chuàng)建項(xiàng)目 
  31. def CreateProject(projectName){ 
  32.     apiUrl = "http://我的sonar服務(wù)器地址/api/projects/create?name=${projectName}&project=${projectName}" 
  33.     resultInfo = HttpReq("POST",apiUrl,''
  34.  
  35. //更新語言規(guī)則集 
  36. def UpdateQuality(language,qualityProfile,projectName){ 
  37.     apiUrl = "http://我的sonar服務(wù)器地址/api/qualityprofiles/add_project?language=${language}&qualityProfile=${qualityProfile}&project=${projectName}" 
  38.     resultInfo = HttpReq("POST",apiUrl,''
  39.  
  40.  
  41. //項(xiàng)目授權(quán) 
  42. def ApplyTemplate(projectKey,templateName){ 
  43.     apiUrl = "http://我的sonar服務(wù)器地址/api/permissions/apply_template?projectKey=${projectName}&templateName=${templateName}" 
  44.     resultInfo = HttpReq("POST",apiUrl,''

4 SonarQube項(xiàng)目授權(quán)問題

我們在前面解決了SonarQube掃描前的一些問題,現(xiàn)在開始解決授權(quán)問題。

Sonarqube的授權(quán)配置

  • 用戶首先登陸SonarQube平臺(我們做了GitlabSSO/LDAP集成)
  • 根據(jù)不同的業(yè)務(wù)組對應(yīng)創(chuàng)建一個group
  • 然后將用戶加入到對應(yīng)的group中
  • 根據(jù)業(yè)務(wù)的簡稱創(chuàng)建對應(yīng)的權(quán)限模板
  • 將組和管理員加入權(quán)限模板中
  • 然后將該業(yè)務(wù)的項(xiàng)目批量應(yīng)用權(quán)限模板

親測: 新生成的項(xiàng)目還需要再應(yīng)用權(quán)限模板后才能使對應(yīng)的項(xiàng)目組成員訪問。

解決:在項(xiàng)目掃描后,調(diào)用接口對當(dāng)前項(xiàng)目應(yīng)用對應(yīng)的權(quán)限模板。

  • 項(xiàng)目授權(quán)(應(yīng)用權(quán)限模板):api/permissions/apply_template

請參考👆問題解決中的Jenkinsfile文件。

5 總結(jié)

今天我們解決了常用的幾個問題,當(dāng)然還有可能還會有很多問題待解決??偨Y(jié)一下我們解決問題的思路。

我們將Jenkins和SonarQube做了集成,通過API能夠滿足我們的需求。

我們也可以在Jenkins上面創(chuàng)建一個項(xiàng)目,比如用戶Sonar項(xiàng)目授權(quán)等等。

 

責(zé)任編輯:姜華 來源: DevOps云學(xué)堂
相關(guān)推薦

2009-07-01 18:14:36

JSP亂碼

2010-08-31 13:49:12

CSS

2022-04-02 20:27:30

ETS操作系統(tǒng)鴻蒙

2011-12-02 14:00:21

JavaOOM

2011-08-24 17:41:16

MySQL死鎖

2011-05-06 17:25:58

硒鼓

2021-06-17 08:07:35

Linux 內(nèi)存站崗

2010-06-09 09:39:42

Opensuse雙系統(tǒng)

2025-04-07 07:20:35

SQL慢查詢性能

2016-11-14 10:06:04

大數(shù)據(jù)max位圖

2009-03-04 10:38:36

Troubleshoo桌面虛擬化Xendesktop

2018-11-01 15:26:38

開源軟件安全

2019-10-11 19:45:28

SparkSQLHiveHadoop

2010-12-27 10:48:10

VirtualboxFreedos

2017-06-14 22:11:57

數(shù)據(jù)庫MySQL死鎖

2022-04-06 10:09:17

云服務(wù)云計(jì)算

2009-08-24 10:37:11

Silverlight

2010-05-11 15:09:51

Unix系統(tǒng)

2010-05-31 14:29:20

Cacti中文

2009-02-18 10:25:00

IPv6部署
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號