jenkins~集群分發功能和職責處理

来源:http://www.cnblogs.com/lori/archive/2017/09/27/7604425.html
-Advertisement-
Play Games

jenkins的多節點集群 在進行自動化部署時,你可以按著它們的項目類型去進行分別部署,這樣即可以達到負載均衡,又可以達到一種職責的明確,比如像java的項目你可以使用linux服務來進行部署(拉代碼,還原,編譯,發佈,生成鏡像,推鏡像到倉庫,建立服務等),而對於.net項目你可以使用windows ...


jenkins的多節點集群

在進行自動化部署時,你可以按著它們的項目類型去進行分別部署,這樣即可以達到負載均衡,又可以達到一種職責的明確,比如像java的項目你可以使用linux服務來進行部署(拉代碼,還原,編譯,發佈,生成鏡像,推鏡像到倉庫,建立服務等),而對於.net項目你可以使用windows伺服器來實現jenkins的節點,而它們的入口都是jenkins的master,由它根據每個節點的標記進行分發!

節點各有其責

每個節點一般都會做項目的依賴包還原,代碼編譯,發佈,鏡像的生成,鏡像的推送到倉庫,docker服務的建立等工作,下麵就來說一下這些工作的細節,如windows平臺里的.net項目,它會有一個windows伺服器為它提供自動化部署的服務,使用以下功能。
  1. 編譯
  2. 發佈
  3. 鏡像的生成
  4. 鏡像的推送到倉庫
  5. docker服務的建立

上面步驟對應的部分代碼如下,SH腳本,主要在linux進行部署,如果是在windows上進行部署的話,建議使用powershell腳本。

項目編譯與發佈

  set -ex
  export Publish_Path="obj\Docker\publish"
  echo "項目恢復"
  dotnet restore  
  echo "項目編譯"
  dotnet build
  echo "項目發佈"
  dotnet publish -o obj/Docker/publish
  echo "發佈成功,開始構建docker鏡像"

生成鏡像和推送到倉庫

#!/bin/sh
set -ex
export IMAGE_NAME=microserviceOrder
export Registry_Url="www.lind.cn:8443"
docker build --no-cache --pull -t $IMAGE_NAME ./
docker tag $IMAGE_NAME $Registry_Url/$IMAGE_NAME
docker push $Registry_Url/$IMAGE_NAME

分發與jenkins項目依賴

在建立節點時可以指定它的標簽,使用請求到主jenkins節點後,根據標簽去分發,找到目標的節點,然後去處理相應的工作 根據構建後的項目依賴去實現自動化部署多項目的關聯

以上內容就是我對jenkins集群中各節點職責,請求分發,項目依賴的理解,希望可以幫到正在學習的您!

感謝各位粉絲的支持!

謝謝!


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

-Advertisement-
Play Games
更多相關文章
  • 1. foreach C#編譯器會把foreach語句轉換為IEnumerable介面的方法和屬性。 foreach語句會解析為下麵的代碼段。 調用GetEnumerator()方法,獲得數組的一個枚舉 在while迴圈中,只要MoveNext()返回true,就一直迴圈下去 用Current屬性訪 ...
  • 用socket做了個程式,本地測試沒有問題,發佈到伺服器上時連接不上,用telnet測試連接失敗 伺服器上netstat -a 查看埠情況,127.0.0.1綁定埠9300處於監聽狀態,如下圖: 修改socket綁定IP為伺服器IP,埠狀態變為下圖: telnet連接測試成功! 很納悶,查了下 ...
  • 問題的產生的背景 由於我們使用了jenkins進行部署(jenkins~集群分發功能和職責處理),而對於.net core項目來說又是跨平臺的,所以對它的項目拉取,包的還原,項目的編譯和項目的發佈都是在一臺linux的jenkins節點上進行的,而我們開發時是在windows系統,所以在進行還原和編 ...
  • Tips 原文作者:Thomas Anderson, Blinkist 原文地址:Steve Jobs was successful because he mastered 'deep work' — here's how you can, too 你喝過麥卡倫姆威士忌嗎?如果你有這樣的經歷,你一定 ...
  • 出於安全考慮,在後臺與前臺進行數據傳輸時,往往不會直接傳輸實體模型,而是使用Dto(Data transfer object 數據傳輸對象),這樣在後臺往前臺傳遞數據時可以省略不必要的信息,只保留必要的信息,大大增強數據安全性。 下麵給出兩個相互對應的關係模型User、UserDto public ...
  • 使用EntityFramework Code First開發,數據遷移是一個不得不提的技術。 在我們的開發過程中,難免需要對模型進行改進,模型改進後,會導致實體集與資料庫不一致,當然我們可以通過刪除資料庫然後再重構資料庫,但是在生產環境中這樣做,這樣或多或少會出現一些問題。使用“數據遷移”,可以幫助 ...
  • 由於HTTP協議是無狀態的,但對於認證來說,必然要通過一種機制來保存用戶狀態,而最常用,也最簡單的就是Cookie了,它由瀏覽器自動保存併在發送請求時自動附加到請求頭中。儘管在現代Web應用中,Cookie已略顯笨重,但它依然是最為重要的用戶身份保存方式。在 "上一章" 中整體的介紹了一下 ASP. ...
  • 1 概述 1 概述 如下例子,你覺得有什麼問題?如你能很快的找出問題,並且解決它,那麼你可以跳過本篇文章,謝謝~~。 想一分鐘,OK,如果沒想出來,可以往下看,下圖標註處即為問題處。 ok,本篇文章就是來解決該問題的。也就是接下來要與大家分享的System.DBNULL類型。 2 內容分享 2 內容 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...