Jenkins 憑證管理 - 看這一篇就夠了~

許多三方網站和應用可以與 Jenkins 交互,如 Artifact 倉庫,基于云的存儲系統和服務等. 在 Jenkins 中添加/配置 credentials,Pipeline 項目就可以使用 credentials 與三方應用交互

image

Credential 類型

參考: https://jenkins.io/zh/doc/book/using/using-credentials/

Jenkins 可以存儲以下類型的 credentials:

  • Secret text - API token 之類的 token (如 GitHub 個人訪問 token)

  • Username and password - 可以為獨立的字段,也可以為冒號分隔的字符串:username:password(更多信息請參照 處理 credentials)

  • Secret file - 保存在文件中的加密內容

  • SSH Username with private key - SSH 公鑰/私鑰對

  • Certificate - a PKCS#12 證書文件 和可選密碼

  • Docker Host Certificate Authentication credentials.

Credential 安全

為了最大限度地提高安全性,在 Jenins 中配置的 credentials 以加密形式存儲在 Jenkins 主節點上(用 Jenkins ID 加密),并且 只能通過 credentials ID 在 Pipeline 項目中獲取

這最大限度地減少了向 Jenkins 用戶公開 credentials 真實內容的可能性,并且阻止了將 credentials 復制到另一臺 Jenkins 實例

Credential 創建

  • 選擇適合的憑證類型

    image
  • 創建 “Username and password” 憑證


    image
  • 創建 “SSH Username with private key” 憑證

    image

Credential ID 定義

  • 在 ID 字段中,必須指定一個有意義的Credential ID- 例如 jenkins-user-for-xyz-artifact-repository。注意: 該字段是可選的。 如果您沒有指定值, Jenkins 則 Jenkins 會分配一個全局唯一 ID(GUID)值。

  • 請記住: 一旦設置了 credential ID,就不能再進行更改。

Credential 使用

參考: https://www.jenkins.io/doc/book/pipeline/jenkinsfile/#handling-credentials

存儲在 Jenkins 中的 credentials 可以被使用:

  1. 適用于 Jenkins 的任何地方 (即全局 credentials),

  2. 通過特定的 Pipeline 項目/項目 (在 處理 credentials 和 使用 Jenkinsfile 部分了解更多信息),

  3. 由特定的 Jenkins 用戶 (如 Pipeline 項目中創建 Blue Ocean的情況).

    • Blue Ocean 自動生成一個 SSH 公共/私有密鑰對, 確保 SSH 公共/私有秘鑰對在繼續之前已經被注冊到你的 Git 服務器

實際使用中,下面幾個場景會用到 creential

  • gitlab 訪問、API 調用
  • jenkins slave 創建

Credential 相關插件

注意: 上述 Credential 類型都依賴于 jenkins 插件,同樣 jenkins pipeline 也需要這些插件的安裝以支持代碼片段

  • Credentials Binding: https://plugins.jenkins.io/credentials-binding/

    • For secret text, usernames and passwords, and secret files
    environment {
    MAGE_REPO_CREDENTIALS = credentials('COMPOSER_REPO_MAGENTO')
    COMPOSER_AUTH = """{
      "http-basic": {
          "repo.magento.com": {
              "username": "${env.MAGE_REPO_CREDENTIALS_USR}",
              "password": "${env.MAGE_REPO_CREDENTIALS_PSW}"
          }
      } }"""
    }
    
    • For other credential types
    withCredentials([usernamePassword(credentialsId: 'amazon', usernameVariable: 'USERNAME', passwordVariable: 'PASSWORD')]) {
    // available as an env variable, but will be masked if you try to print it out any which way
    // note: single quotes prevent Groovy interpolation; expansion is by Bourne Shell, which is what you want
    sh 'echo $PASSWORD'
    // also available as a Groovy variable
    echo USERNAME
    // or inside double quotes for string interpolation
    echo "username is $USERNAME"
    }
    
  • Jenkins Plain Credentials Plugin: https://plugins.jenkins.io/plain-credentials/

    image
  • SSH Credentials: https://plugins.jenkins.io/ssh-credentials/

最佳實踐

  • 為了便于管理和使用, 強烈建議使用統一的約定來指定 credential ID

  • 建議使用類似下面的 format 做為 credential ID, 便于 jenkinsfile 開發時直接使用,同時在”描述“里寫清楚 credential 的作用

    gitlab-api-token、gitlab-private-key、gitlab-userpwd-pair、harbor-xxx-xxx

    image

實踐:

  • 如下所示,將憑證使用統一的 ID 命名之后,便于復用,憑證定義一次,可多次,多個地方統一使用,無論是后期維護,復用都非常方便!

        environment {
            // HARBOR="harbor.devopsing.site"
            HARBOR_ACCESS_KEY = credentials('harbor-userpwd-pair')
            SERVER_ACCESS_KEY = credentials('deploy-userpwd-pair')
                }
    
        docker login --username=${HARBOR_ACCESS_KEY_USR} --password=${HARBOR_ACCESS_KEY_PSW} ${HARBOR}
        sshpass -p "${SERVER_ACCESS_KEY_PSW}" ssh -o StrictHostKeyChecking=no ${SERVER_ACCESS_KEY_USR}@${DEPLOY_SERVER} "$runCmd"
    
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,578評論 6 544
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,701評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,691評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,974評論 1 318
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,694評論 6 413
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 56,026評論 1 329
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 44,015評論 3 450
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 43,193評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,719評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,442評論 3 360
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,668評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,151評論 5 365
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,846評論 3 351
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,255評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,592評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,394評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,635評論 2 380