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

字母哥部落格發表於2022-04-25

此文系【大話雲原生】系列第四篇,該系列文章期望用最通俗、簡單的語言說明白雲原生生態系統內的組成、架構以及應用關係。從這篇開始我們要開始針對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

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

相關文章