【大話雲原生】kubernetes灰度發佈篇-從步行到坐纜車的自動化服務升級

来源:https://www.cnblogs.com/zimug/archive/2022/04/25/16188577.html
-Advertisement-
Play Games

此文系【大話雲原生】系列第四篇,該系列文章期望用最通俗、簡單的語言說明白雲原生生態系統內的組成、架構以及應用關係。從這篇開始我們要開始針對Kubernetes進行介紹了,本文內容如下: 一、Kubernetes的Pod概念解析 前文說到老婆過生日了我們一起出去旅游,上了團體服務班車,小娜同學(老婆) ...


此文系【大話雲原生】系列第四篇,該系列文章期望用最通俗、簡單的語言說明白雲原生生態系統內的組成、架構以及應用關係。從這篇開始我們要開始針對Kubernetes進行介紹了,本文內容如下:

一、Kubernetes的Pod概念解析

前文說到老婆過生日了我們一起出去旅游,上了團體服務班車,小娜同學(老婆)閑聊到:“這服務還不錯哈,2個跟車導游,1個司機”。三句不離老本行,我無聊的說到:“他們三個人就是一個Pod,提供一天的旅游服務內容,有主有次不可分割"。

file

小娜同學又上套了:“什麼是Pod啊?英文單詞豌豆莢?”,讓老婆增加對老公崇拜感的機會不可多得,那就開講,反正坐車也是閑著。

  • 一般來說一個Pod提供一種服務(微服務),“哎?之前說容器的時候你也是這麼說的”。是的,容器是提供服務的最小單元,那麼Pod是什麼概念?這是因為我們現在討論的是k8s,Pod是k8s服務調度的最小單元
  • “為什麼引入Pod的概念?”,因為有的時候你會發現:一個服務通常包含輔助它的服務。比如這個車上,一個導游長得漂亮口才好作為主導游提供核心講解服務,還有一個輔助她的導游負責發帽子、統計人數、統計消費等。同理回到架構技術角度,一個nginx提供web服務容器作為核心服務容器,負責收集nginx日誌的服務容器作為輔助服務和它部署在一起,這樣方便日誌收集與連接。
  • 一個Pod存在一個基礎容器Infra,基礎容器Infra提供了網路共用的能力,就像主導游和輔助導游必須在一輛車(基礎容器Infra)上,或者基於這輛車組成了一個組合,否則他們之間無法對話及資源共用。
  • 一個Pod下的容器共用網路及數據捲,所以將容器服務間具有相當強的捆綁關係的服務容器放到一個Pod裡面,通常一個容器提供核心服務,其他的容器提供輔助服務,如:日誌收集、監控告警等。

二、Pod標簽與Service服務

聊著聊著很快車就到了旅游目的地,一下車發現X公司的團隊還真不少。導游都統一都帶上了深紅色的帽子(游客帶上藍色遮陽帽),浩浩蕩蕩出發。深紅色的帽子為導游打上了標簽,他們面向游客(用戶)提供了統一的一種服務叫做:“導游服務”。

file

對於K8s中的服務架構也是一樣的:

  • 一個Pod通常提供一種服務,如nginx web訪問服務
  • 多個提供同樣服務的Pod通常打上一樣的標簽
  • 創建Service:具備同一種標簽的Pod組成一個Service,對外提供服務。

三、自動化服務升級-灰度發佈

我們今天的項目是爬山,提供了兩種方式:一是直接爬(即步行),二是坐纜車,當然如果你中途爬不動了也可以在纜車換乘站上纜車。

  • 步行到纜車可以理解為一次服務升級(1.0版本服務升級為2.0版本服務)。從技術角度,服務升級等同於新版本服務的部署被稱為Deployment。K8s同樣使用Deployment這個術語代表服務升級部署。
  • ReplicaSet代表一個版本的Pod服務組合,1.0步行版本的Pod服務組合,2.0為纜車版本的Pod服務組合,這樣理解是不是容易多了呢?
  • 在服務容器部署Deployment的過程中,不希望服務中斷(即:不希望對步行1.0的用戶的服務出現中斷情況),所以停掉一個1.0的Pod,再啟動一個2.0的Pod2.0,這個過程被稱為灰度發佈。整個過程高度依賴Kubernetes提供的自動化運維能力。

file

上面的圖每個RS只有2個Pod,還不能那麼直觀的理解灰度發佈,看下麵這張圖

  • 圓形代表Pod,分為v1版本和v2版本,虛線標識的Pod表示即將下線的Pod
  • v1版本的Pod減一,v2版本的pod加一
  • 逐漸ReplicaSet:v1的Pod全部銷毀,ReplicaSet:v2的Pod逐漸被創建並啟動提供服務
  • 整個的灰度發佈過程,在k8s種通過一個Deployment進行定義。

file
此專欄《大話雲原生》的前三篇文章如下

  • 《【大話雲原生】煮餃子與docker、kubernetes之間的關係》
  • 《【大話雲原生】負載均衡篇-小飯館的流量變大了》
  • 《【大話雲原生】微服務篇-五星級酒店的服務方式》

如果您讀完了覺得有收穫,期待您能轉發分享,您的支持是我不竭的創作動力!

歡迎關註我的博客,更多精品知識合集

本文轉載註明出處(必須帶連接,不能只轉文字):字母哥博客 - zimug.com

覺得對您有幫助的話,幫我點贊、分享!您的支持是我不竭的創作動力!。另外,筆者最近一段時間輸出瞭如下的精品內容,期待您的關註。


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

-Advertisement-
Play Games
更多相關文章
  • 前端性能優化主要分兩塊: 一是資源載入 1.多使用記憶體、緩存和其他方法 2.減少CPU計算量,減少網路載入耗時。 以上適用所有編程的性能優化-空間換時間 3.減少資源體積:壓縮代碼,圖片精靈 4.減少訪問次數:合併代碼(js模塊化,最後打包成一個JS)、SSR伺服器端渲染,緩存 5.使用更快的CDN ...
  • 最近項目中需要實時播放攝像頭rtsp視頻流,於是就專門做了些研究。而瀏覽器不能直接播放,只有通過插件或者轉碼來實現這個需求。 要實現這個目的,可以採用的方案非常得多,有商業的也有開源的,這裡主要列舉一些開源的方案。這裡的方案都是我嘗試過了的,有些成功,有些沒成功。但是因為每個項目情況不同,這次沒成的 ...
  • 前段時間在Android原生搞的BLE掃碼槍又要移植到小程式上來。本以為小程式不支持BLE的,結果一搜,還真支持-_-|| 。 藍牙部分問題不大,遇到的主要問題是,小程式環境如何對字元編碼進行判斷以及如何進行編碼轉文字的問題。 掃了一陣,搜到了TextDecoder。結果小程式環境不支持……。 隨後 ...
  • 一、從用戶請求到瀏覽器渲染的過程大致如下 1.用戶輸入功能變數名稱,然後DNS解析成IP地址 2.瀏覽器根據IP地址請求伺服器 3.伺服器響應http請求,並返回給瀏覽器 4.瀏覽開始渲染: 。根據html,生成DOM TREE 。根據css,生成CSS TREE 。將DOM TREE和CSS TREE結合 ...
  • BIM模型輕量化顯示地圖引擎、BIM模型文件轉換引擎、BIM線上編輯器是BIM模型輕量化的核心技術,具有一定的技術門檻。易景空間ESMap本著開放的精神,把核心技術提供給廣大的BIM開發者,使得開發者即使沒有掌握任何圖形技術,也能輕鬆開發強大的BIM應用。 ...
  • 背景介紹 當頁面內容很多的時候,用戶可能會一直往下滑動頁面。但是當他想返回頁面頂部進行其他操作時,他可能需要不斷滾動滑鼠滾輪,這就導致用戶體驗將很差。鑒於這種情況, “回到頂部”這一功能便出現了。 如今在我們瀏覽網站的時候,常常能遇見“回到頂部”這個按鈕。目前主流的回到頁面頂部分表現為兩種,一種是直 ...
  • 狀態模式是什麼 狀態模式是一種行為設計模式,讓你能在一個對象的內部狀態變化時改變其行為,使其看上去就像改變了自身所屬的類一樣。 為什麼要用狀態模式 如果對象需要根據自身當前狀態進行不同行為,同時狀態的數量非常多且與狀態相關的代碼會頻繁變更的話,可使用狀態模式。相似狀態和基於條件的狀態機轉換中存在許多 ...
  • 本篇主要講從技術體繫到商業洞察,分為五個小節,新一代開發範式雲原生、建立自己的技術體系、技術判斷力、技術業務產業周期,技術與商業洞察。對於新一代開發範式和技術體系的建立,文字部分我就不再補充,具體可以看看PPT。這裡我想講技術判斷力和商業洞察,這是建立技術體系之後,對關鍵點的判斷和洞察,是從點到面再 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...