国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

一篇文章帶你了解kubernetes各組件間的通信機制

云計算
我們對kubernetes有了一定的認識,本文我們將繼續深入的對kubernetes在系統層面上進行討論,一起看看kubernetes的各個基本組件,以及各個組件是如何相互配合來撐起如此復雜的集群系統。

 我們對kubernetes有了一定的認識,本文我們將繼續深入的對kubernetes在系統層面上進行討論,一起看看kubernetes的各個基本組件,以及各個組件是如何相互配合來撐起如此復雜的集群系統。下面跟隨文章內容,一起來領略kubernetes令人驚嘆的設計內幕吧。

[[281210]]

 

Kubernetes的基本組件

Kubernetes將整個集群分為控制節點和工作節點,如下圖所示。

 

一篇文章帶你了解kubernetes各組件間的通信機制

 

Kubernetes中的Master是指集群控制節點,每個Kubernetes集群中需要一個Master節點來負責整個集群的管理和控制,Kubernetes中所有的控制指令都是交由Master來進行處理。引起在集群中處于非常重要的地位,因此在部署中需進行多節點單獨部署。

Maste節點關鍵進程

 

一篇文章帶你了解kubernetes各組件間的通信機制

 

Apiserver:提供kubernetes所有資源增刪改查的唯一入口,也是集群控制的入口,提供http Rest接口,完成集群管理,資源配額,訪問控制,認證授權,以及對etcd的操作。

Controller-manager:是集群內所有資源對象的自動化控制中心,負責pod和node的管理,節點控制器,服務控制器,副本控制器,服務賬戶和令牌控制器等

Scheduler:負責資源調度,監聽Apiserver,查詢是否有未調度的pod。

Etcd:在kubernetes系統中,主要有兩個服務需要用到etcd來存儲:

網絡插件:如flannel等需要存儲網絡配置信息

Kubernetes本身,包括各種對象的狀態和原信息配置。

除Master節點外,集群中其他集群被稱為Node節點,較早的版本中也叫Minion。Node節點是集群中具體的工作負載節點,其可以使物理機也可以為虛擬機。

Node節點關鍵進程(包括但不限于以下進程)

 

一篇文章帶你了解kubernetes各組件間的通信機制

 

kubelet:處理Master下發到本節點的任務,管理pod及pod的容器,每個kubelet在Apiserver上注冊自身信息,定期向Master匯報節點的資源使用情況,并通過cAdvisor監控容器和節點信息。

kube-proxy:將到service的訪問轉發到后端的多個pod實例上,維護路由信息,對于每一個TCP類型的k8s service,kube-proxy會在本地建立一個sockerserver來負責均衡算法,使用rr負載均衡算法。

CNI網絡組件:作為容器平臺的網絡標準化組件,為容器提供跨網段的通信支持,是kubernetes集群overlay網絡的實現關鍵。

Docker:kubernetes支持多種容器工具,目前Docker作為主流的容器,為kubernetes集群提供容器創建及管理。

 

集群各組件間的交互

Kubernetes為所有資源增刪改查的唯一入口,各組件均以list-watch的方式向Apiserve發送請求。為減少Apiserver的壓力,各組件都采用緩存來緩存數據。功能模塊在某些情況下不直接訪問Apiserver,而是通過訪問緩存來間接訪問Apiserver。

Kubelet&Apiserver

每個node上的kubelet每個一個時間周期,就會調用Apiserver的REST接口來報告自身狀態。Kubelet通過watch接口,監聽pod信息。監聽創建、刪除、修改事件。

Controller-manager&Apiserver

controller-manager中包含多個controller,舉例:Node Controller模塊通過API server提供的Watch接口,實現監控Node信息,并做相應處理。

Scheduler&Apiserver

Scheduler通過API server的watch接口來監聽,監聽到新建pod副本后,檢索所有符合該Pod要求的Node列表,開始執行Pod調度,調度成功后將pod綁定到具體節點。

以下是一張典型pod創建的流程圖,其中可以看到Apiserver處于核心的位置,集群內的各個功能模塊的所有原數據正刪改查都是通過kube-apiserver操作etcd,當需要獲取和操作這些數據時,通過Apiserver的REST接口來實現。

 

一篇文章帶你了解kubernetes各組件間的通信機制

 

 

[[281211]]

 

list-watch機制

kubernetes沒有像其他分布式系統中額外引入MQ,是因為其設計理念采用了level trigger而非edge trigger。其僅僅通過http+protobuffer的方式,實現list-watcher機制來解決各組件間的消息通知。因此,在了解各組件通信前,必須先了解list-watch機制在kubernetes的應用。

List-watch是k8s統一的異步消息處理機制,list通過調用資源的list API羅列資源,基于HTTP短鏈接實現;watch則是調用資源的watch API監聽資源變更事件,基于HTTP長鏈接實現。在kubernetes中,各組件通過監聽Apiserver的資源變化,來更新資源狀態。

這里對watch簡要說明,流程如下圖所示:

 

一篇文章帶你了解kubernetes各組件間的通信機制

 

這一部分流程圖看起來并不復雜,實際上里面的實現相當精妙。結合這幅圖進行簡要的解釋:

1 首先需要強調一點,list或者watch的數據,均是來自于etcd的數據,因此在Apiserver中,一切的設計都是為了獲取最新的etcd數據并返回給client。

2 當Apiserver監聽到各組件發來的watch請求時,由于list和watch請求的格式相似,先進入ListResource函數進行分析,若解析為watch請求,便會創建一個watcher結構來響應請求。watcher的生命周期是每個http請求的。

  1. //每一個Watch請求對應一個watcher結構 
  2. func (a *APIInstaller) registerResourceHandlers(path string, storage rest.Storage,... ... 
  3. …… 
  4. lister, isLister := storage.(rest.Lister) 
  5. watcher, isWatcher := storage.(rest.Watcher) ...(1) ... case "LIST": // List all resources of a kind. 
  6. …… 

3 創建了watcher,但誰來接收并緩存etcd的數據呢?Apiserver使用cacher來接收etcd的事件,cacher也是Storage類型,這里cacher可以理解為是監聽etcd的一個實例,cacher針對于某個類型的數據,其cacher通過ListAndWatch()這個方法,向etcd發送watch請求。etcd會將某一類型的數據同步到watchCache這個結構,也就是說,ListAndWatch()將遠端數據源源不斷同步到cacher結構中來。Cacher的結構如下所示:

  1. type Cacher struct { 
  2.  incomingHWM storage.HighWaterMark 
  3.  incoming chan watchCacheEvent 
  4.  sync.RWMutex 
  5.  // Before accessing the cacher's cache, wait for the ready to be ok. 
  6.  // This is necessary to prevent users from accessing structures that are 
  7.  // uninitialized or are being repopulated right now. 
  8.  // ready needs to be set to false when the cacher is paused or stopped. 
  9.  // ready needs to be set to true when the cacher is ready to use after 
  10.  // initialization. 
  11.  ready *ready 
  12.  // Underlying storage.Interface. 
  13.  storage storage.Interface 
  14.  // Expected type of objects in the underlying cache. 
  15.  objectType reflect.Type 
  16.  // "sliding window" of recent changes of objects and the current state. 
  17.  watchCache *watchCache 
  18.  reflector *cache.Reflector 
  19.  // Versioner is used to handle resource versions. 
  20.  versioner storage.Versioner 
  21.  // newFunc is a function that creates new empty object storing a object of type Type. 
  22.  newFunc func() runtime.Object 
  23.  // indexedTrigger is used for optimizing amount of watchers that needs to process 
  24.  // an incoming event. 
  25.  indexedTrigger *indexedTriggerFunc 
  26.  // watchers is mapping from the value of trigger function that a 
  27.  // watcher is interested into the watchers 
  28.  watcherIdx int 
  29.  watchers indexedWatchers 
  30.  // Defines a time budget that can be spend on waiting for not-ready watchers 
  31.  // while dispatching event before shutting them down. 
  32.  dispatchTimeoutBudget *timeBudget 
  33.  // Handling graceful termination. 
  34.  stopLock sync.RWMutex 
  35.  stopped bool 
  36.  stopCh chan struct{} 
  37.  stopWg sync.WaitGroup 
  38.  clock clock.Clock 
  39.  // timer is used to avoid unnecessary allocations in underlying watchers. 
  40.  timer *time.Timer 
  41.  // dispatching determines whether there is currently dispatching of 
  42.  // any event in flight. 
  43.  dispatching bool 
  44.  // watchersBuffer is a list of watchers potentially interested in currently 
  45.  // dispatched event. 
  46.  watchersBuffer []*cacheWatcher 
  47.  // blockedWatchers is a list of watchers whose buffer is currently full
  48.  blockedWatchers []*cacheWatcher 
  49.  // watchersToStop is a list of watchers that were supposed to be stopped 
  50.  // during current dispatching, but stopping was deferred to the end of 
  51.  // dispatching that event to avoid race with closing channels in watchers. 
  52.  watchersToStop []*cacheWatcher 
  53.  // Maintain a timeout queue to send the bookmark event before the watcher times out
  54.  bookmarkWatchers *watcherBookmarkTimeBuckets 
  55.  // watchBookmark feature-gate 
  56.  watchBookmarkEnabled bool 
  57. }  

watchCache的結構如下所示:

  1. type watchCache struct { 
  2.  sync.RWMutex //同步鎖 
  3.  cond *sync.Cond //條件變量 
  4.  capacity int//歷史滑動窗口容量 
  5.  keyFunc func(runtime.Object) (string, error)//從storage中獲取鍵值 
  6.  getAttrsFunc func(runtime.Object) (labels.Set, fields.Set, bool, error)//獲取一個對象的field和label信息 
  7.  cache []watchCacheElement//循環隊列緩存 
  8.  startIndex int//循環隊列的起始下標 
  9.  endIndex int//循環隊列的結束下標 
  10.  store cache.Store// 
  11.  resourceVersion uint64 
  12.  onReplace func() 
  13.  onEvent func(*watchCacheEvent)//在每次緩存中的數據發生Add/Update/Delete后都會調用該函數,來獲取對象的之前版本的值 
  14.  clock clock.Clock 
  15.  versioner storage.Versioner 

cache里面存放的是所有操作事件,而store中存放的是當前最新的事件。

4 cacheWatcher從watchCache中拿到從某個resourceVersion以來的所有數據,即initEvents,然后將數據放到input這個channel里面去,通過filter然后輸出到result這個channel里面,返回數據到某個client。

  1. type cacheWatcher struct { 
  2.  sync.Mutex//同步鎖 
  3.  input chan *watchCacheEvent//輸入管道,Apiserver都事件發生時都會通過廣播的形式向input管道進行發送 
  4.  result chan watch.Event//輸出管道,輸出到update管道中去 
  5.  done chan struct{} 
  6.  filter filterWithAttrsFunc//過濾器 
  7.  stopped bool 
  8.  forget func(bool) 
  9.  versioner storage.Versioner 

 

從一個pod創建過程看k8s組件通信

我們再回到上面的Pod創建流程圖。從圖中我們可以看出以下信息:

1 首先各組件也會在初始化時向Apiserver發送watch請求,即在圖中標0的指令。Apiserver在創建kubeApiserver并注冊各API路由信息時,獲取Watch請求的路由信息

2 從Kubectl向Apiserver發送創建pod請求起,每一步創建、更新操作,都會存儲到etcd中。

3 各組件向Apiserver發送watch請求,Apiserver從etcd獲取最新數據并返回。

注意:當事件發生時,Apiserver會給這些watcher中的通道推送,每個watcher都有自己的Filter過濾,找到自己想要監聽的事件則通過管道的方式將該數據發送到相應的組件。

責任編輯:武曉燕 來源: 今日頭條
相關推薦

2023-05-12 08:19:12

Netty程序框架

2021-06-30 00:20:12

Hangfire.NET平臺

2021-01-12 09:04:12

Django FormForm組件開發

2021-02-02 18:39:05

JavaScript

2020-11-10 10:48:10

JavaScript屬性對象

2021-01-29 18:41:16

JavaScript函數語法

2021-06-04 09:56:01

JavaScript 前端switch

2025-03-07 10:04:12

2023-05-08 08:21:15

JavaNIO編程

2021-03-05 18:04:15

JavaScript循環代碼

2021-09-27 09:18:30

ListIterato接口方法

2021-05-18 08:30:42

JavaScript 前端JavaScript時

2023-07-30 15:18:54

JavaScript屬性

2021-03-09 14:04:01

JavaScriptCookie數據

2024-04-19 14:23:52

SwitchJavaScript開發

2024-01-30 13:47:45

2021-01-26 23:46:32

JavaScript數據結構前端

2021-06-24 09:05:08

JavaScript日期前端

2021-02-26 20:01:57

SVG濾鏡元素

2023-09-06 14:57:46

JavaScript編程語言
點贊
收藏

51CTO技術棧公眾號

一区二区国产日产| 久久综合九色综合久久久精品综合| 精品国产乱码久久久久久图片 | 久草精品在线观看| 国产特黄在线| 日韩天堂在线观看| 成人国产1314www色视频| 最新在线观看av| 欧美一区二区三区另类| 在线观看视频一区| 欧美aaaaa喷水| 岛国在线视频网站| 91小视频在线观看| 国产91精品不卡视频| 玩弄japan白嫩少妇hd| 日韩中文字幕在线精品| 久久国产精品免费精品3p| 欧美日韩国产首页| 精品国产乱码久久久久久郑州公司 | 写真片福利在线播放| 色天天色综合| 欧美日韩中文在线| 久久久久无码国产精品一区| 一区二区三区电影大全| 久久精品亚洲乱码伦伦中文| 日韩av免费看| www.视频在线.com| 成人av网址在线观看| 国产精品久久久久高潮| 视频福利在线| 视频在线观看一区| 欧美成人亚洲成人| 日本福利在线观看| 日本中文字幕一区二区视频| 色偷偷av亚洲男人的天堂| jizz18欧美| 亚洲精选久久| 久久国产色av| 麻豆精品av| 国产在线观看一区二区三区| 肉体视频在线| 国产无人区一区二区三区| 91欧美日韩一区| 在线观看网站免费入口在线观看国内 | 性网站在线免费观看| 亚洲精选在线视频| 一区二区三区日韩欧美| 国产精品日韩专区| 国产免费拔擦拔擦8x在线播放 | 欧美天堂亚洲电影院在线观看| 欧美成人在线直播| 成人国产精品色哟哟| hd国产人妖ts另类视频| 中文字幕欧美国产| 日韩欧美精品在线不卡| 日韩精品导航| 中文字幕第一页久久| 久久国产精品一区二区三区四区| 国产免费视频在线| 3d动漫精品啪啪1区2区免费| 99在线高清视频在线播放| 亚洲久久一区| 欧美视频免费看欧美视频| 最新国产精品| 尤物国产精品| 国产精品99一区二区| 亚洲电影一二三区| 国产精品麻豆久久| 欧美成人精品xxx| 91视频综合| 欧美成人高清视频| 999久久久精品国产| 在线免费观看一区二区三区| 日本一区二区三区视频视频| www亚洲国产| 亚洲精品123区| 91猫先生在线| 国产精品综合av一区二区国产馆| 九九九九精品| 久久欧美一区二区| 中文字幕日本在线| 91电影在线观看| 青青在线精品| 一区二区三区动漫| 男女在线观看视频| 欧美日韩国产色站一区二区三区| 亚洲tv在线| 国产一区二区三区av在线| 久久在线播放| 狠狠精品干练久久久无码中文字幕| 麻豆九一精品爱看视频在线观看免费| 91久久精品在线| 国产成人啪午夜精品网站男同| 日本精品免费| 在线看三级网站视频| 亚洲免费视频成人| 无码 制服 丝袜 国产 另类| av在线这里只有精品| 亚洲影视九九影院在线观看| 厕沟全景美女厕沟精品| 97成人在线视频| 自拍偷拍亚洲图片| 久久精品中文字幕电影| 久久久免费人体| 日韩一区在线视频| 亚洲精选91| 自拍偷拍电影| 色综合天天视频在线观看| 亚洲人性生活视频| 一本色道久久综合亚洲aⅴ蜜桃| av在线国产精品| 性欧美.com| 久久se精品一区精品二区| 午夜精彩视频| 久久视频在线播放| av国产精品| 在线观看亚洲视频啊啊啊啊| 欧美在线色视频| 在线观影网站| 欧美激情女人20p| 国产99精品| jlzzjlzz欧美| 亚洲成人tv网| 91av成人在线| 日韩欧美1区| 91成人免费电影| 66视频精品| www.国产区| 亚洲sss视频在线视频| 在线理论视频| 91av视频在线免费观看| 国产人久久人人人人爽| 福利视频一区| 国产精品精品一区二区三区午夜版 | 蜜桃狠狠色伊人亚洲综合网站| 精品福利在线视频| 成人在线免费看黄| 色偷偷av一区二区三区乱| 国产精品一区二区久久不卡| www.51av欧美视频| 艳母动漫在线免费观看| 亚洲美女久久久| 欧美综合自拍| 精品国产一二| 欧美日韩国产a| 久久精品女人| av中文在线资源| 一级黄色录像免费看| 日韩中文字幕欧美| 国产精品美女久久福利网站| 日本三级在线播放完整版| 精品视频在线播放| 久久国产精品色av免费看| av天天在线| 69堂成人精品视频免费| 国产一区二区在线免费观看| 调教视频vk| 日韩丝袜美女视频| 国产老肥熟一区二区三区| 亚洲美女色播| 丝袜国产免费观看| 香蕉成人app免费看片| 男人天堂1024| 精品在线观看国产| 欧美午夜久久| 18av在线播放| 在线中文字幕不卡| 亚洲精选在线| 黄色aa久久| 亚洲三级视频网站| 欧美一区二区三区播放老司机| 日韩精品一区二区三区中文字幕 | 国产亚洲精品久久| 亚洲国产精品日韩专区av有中文| 国产精品影院在线| 麻豆md0077饥渴少妇| 日韩欧美综合在线视频| 美女网站久久| 日韩中文字幕一区二区高清99| 中文字幕乱在线伦视频乱在线伦视频| 免费成人av网站| 久久久999精品免费| 色综合久久久久网| 国产精品亚洲午夜一区二区三区| 欧美人体视频| 色网在线观看| 国产精品粉嫩av| 日韩视频免费大全中文字幕| 亚洲欧美成人一区二区三区| 99精品国产在热久久下载| 天堂中文字幕| 精品伦精品一区二区三区视频| 日韩中文字幕在线视频| 精品久久久国产精品999| 久久97超碰国产精品超碰| 成人羞羞动漫| 成人xxxx| 国产性生活免费视频| 91九色在线视频| 欧美黑人巨大精品一区二区|