Jenkins多環境持續集成架構實踐

来源:https://www.cnblogs.com/heyuquan/archive/2019/12/23/jenkins-multi-env-cicd-architecture.html
-Advertisement-
Play Games

使用jenkins實現多分支、多環境,多項目、多套配置文件、多編程語言的應用"一鍵發佈"和"一鍵回滾"的架構實踐 ...


 

     自動化部署主要是為瞭解決項目多、環境多、持續集成慢、部署操作麻煩、手動操作易出錯、自動化運維等問題。

Jenkins是開源CI&CD軟體領導者, 提供超過1000個插件來支持構建、部署、自動化, 滿足任何項目的需要。

目標

l  支持多分支、多環境、多項目、多套配置文件、多編程語言

l  支持一鍵構建、集群發佈

l  支持一鍵回滾歷史版本

l  快捷配置添加新的部署項目

l  支持多個項目使用同一個job發佈或回滾

另外:也可以根據需要加入gitlab自動觸發構建、自動化測試、釘釘通知、郵箱通知等需求

 

本實踐使用到的技術,可參考:《[CI&CD]jenkins自動化工具使用教程》

技術關鍵詞:jenkins master-slavejenkins 插件(multijobEnvInject),rsync工具,powershelldotnet core cliicacls工具等等

目錄

最終效果圖... 1

目錄設計... 2

約定及規範... 3

架構設計... 4

#、CICD架構圖... 4

#、項目映射配置文件設計... 5

#、一鍵發佈job設計... 6

#、一鍵回滾job設計... 8

#、簡易多環境CICD流程... 8

 

最終效果圖

一鍵發佈

 

publish-01

 

一鍵回滾

 

 rollback-01

目錄設計

Jenkins相關目錄設計

----jenkins-ex             jenkins構建時使用到的目錄

--software            Jenkins安裝目錄

  --master

  --slave

--backup              jenkins備份目錄

  --master

--module             功能模塊,每一類功能相關的文件放在對應的子文件夾中

  --common

    --script          各模塊公用的腳本

--publish          發佈功能

    --settings

      --config     構建時配置文件。Eg: jenkins_profile.pubxml、項目配置文件等

        -- test-publish-template-app-config.json項目映射配置表

         --script      Jenkins job構件時調用的腳本(方法封裝)

--source-code      拉取的源代碼存放目錄

  --test

            --系統標識

              --應用名

    --build-result              構建產物(編譯後的結果)

  --test

            --系統標識

              --應用名

    --temp-file    臨時文件,job執行過程中產生的文件

      --builder-history      構建歷史記錄文件

      --job-params          構建過程中傳遞參數的文件

    --app-config  應用對應的環境配置文件

          --test

            --系統標識

              --應用名

  --other-sub-module

……

 

約定及規範

jenkins job命名

#job名全小寫,多單詞用”-”分割。(egpublish-template-onekey-deploy

#job命名約定:模塊名-環境-功能名。(egpublish模塊,publish-test-onekey-deploy

#、模塊中組件job命名約定:模塊-c-組件名。(egpublish-c-pull-code

#job輸入參數以”p_”為首碼

 

Jenkins job中的腳本命名(egpowershell

#、變數全小寫,多單詞用”_”分割

 

規範約定

#、代表路徑的變數值,以”\”結尾

#、備份名字中用“#”做分隔符,還原時好取參數(egp_app_key#2019-1219-1503

 

架構設計

#CICD架構圖

CICD過程主要在兩個區域網中執行:構建伺服器(開發內網)和部署伺服器(生產內網)

 

     jenkins CICD架構圖

#、項目映射配置文件設計

想要實現使用一個job,通過下拉來發佈|回滾不同的項目,我們需要一個靈活的項目配置映射文件,類似如下:

config

 

配置文件選項含義從命名上可以識別,主要包括:環境、代碼分支、部署路徑、拷貝排除文件列表、項目信息(項目唯一標識、目錄文件夾名、源代碼路徑、開發語言、集群節點信息…)等等

       app_config節點下的配置,可以覆蓋父節點配置,適配項目特定的部署要求。

       app_config是數組節點,可以輕鬆添加新的部署項目,實現新項目的快速CICD

 

#、一鍵發佈job設計

一鍵發佈主要經歷的階段有:組合項目相關參數>>獲取最新代碼>>編譯打包>>推送應用文件到伺服器>>應用備份>>拷貝到Temp文件夾>>發佈到部署目錄

為了更好的實現和控制一鍵發佈這些階段,設計瞭如下輸入參數:

publish-02

 

參數名

類型

預設值

說明

p_publish_model

下拉單選

reality

取值:realitydrill

發佈模式
reality
:正常發佈,發佈到應用伺服器應用文件夾,做真實應用發佈部署

drill:演練。發佈到應用伺服器temp文件夾後結束

p_app_key

下拉單選

 

通過這個key到配置文件裡面找站點的具體配置信息

p_do_code_pull

Bool

True

拉取最新代碼

p_do_build_package

Bool

True

是否重新編譯打包

p_do_backup

Bool

True

是否執行備份

p_publish_content

多選

 

取值:app-fileconfig

發佈文件列表(多選)

 

app-file:應用文件(不包含config文件)

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 案例:手風琴 封裝好的動畫函數在common.js裡面 //function getStyle(element, attr) {...} //function animate(element, json, fn) {...} 手風琴設置的是背景圖嗎,backgroudImage="url(image ...
  • 圖文結合深入理解 JS 中的 this 值 在 中最常見的莫過於函數了,在函數(方法)中 的出現頻率特別高,那麼 到底是什麼呢,今天就和大家一起學習總結一下 中的 。 1. 初探this 在 中是一個關鍵字,不是變數也不是屬性名, 中不允許給this賦值。 它是函數運行時,在函數體內部自動生成的一個 ...
  • 聊一聊 JS 輸出為 [object object] 是怎麼回事? 今天在學習ES6中的 數據類型時,在寫demo時控制台輸出為 ,當時有點疑惑,查閱了相關資料後搞清楚了其中的原因。 在解釋之前,由於有些小伙伴可能還沒有接觸過ES6,所以先說一下上面用到的ES6的一些特性: const: 聲明一個常 ...
  • 接續上篇ES6+轉ES5,本篇將使用webpack和babel將多個不同目錄下指定的多個ES6+語法的js文件編譯為ES5,並將編譯後的文件配置註入對應的html文件。 所需環境node、npm、設置淘寶鏡像請參考上篇進行安裝,地址:https://www.cnblogs.com/puyongson ...
  • 1.關於浮動 浮動的元素會脫離標準文檔流(float),從而不占據空間,實現了一行排列多個元素的效果 ,但是又導致上級元素height消失,處理這種情況的方法就是有兩種: 1.第一種在css里寫個偽類,哪些地方需要清除浮動,直接調用類名。 .clearfix::after{ display: blo ...
  • 基於jquery的提示框JavaScript 插件,類Bootstrap [TOC] 源碼 github地址: "https://github.com/Ethan Xie/message" 實例 通過此此插件可以為提示欄添加自動/點擊消失的功能 用法 需引入message.css與message.j ...
  • 第一步: 在 VSCode 中,安裝用於同步配置的插件 settings sync 第二步:將 VSCode 配置上傳到 GitHub 完成這一步需要 GitHub token 和 GitHub gist 進入GitHub 設置界面 & 創建 GitHub token 在這裡找到之前你上傳 VSCo ...
  • 聊一聊 webpack 中的 preloading 和 Prefetching 提到 Preloading 和 Prefetching 就不得不先說一下代碼分割,通過下麵的例子我們來說明為什麼需要代碼分割? 在首次訪問時, index.js 文件的大小為 2 MB,需要載入的大小是 2 MB 業務代 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...