精品国产人成在线_亚洲高清无码在线观看_国产在线视频国产永久2021_国产AV综合第一页一个的一区免费影院黑人_最近中文字幕MV高清在线视频

0
  • 聊天消息
  • 系統消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發帖/加入社區
會員中心
創作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內不再提示

核心組件原理——pod核心原理

倩倩 ? 來源:CSDN ? 作者:CSDN ? 2022-09-20 11:03 ? 次閱讀

1. 核心組件原理 —— pod 核心原理

1.1 pod 是什么

pod 也可以理解是一個容器,裝的是 docker 創建的容器,也就是用來封裝容器的一個容器;

pod 是一個虛擬化分組, 有自己的 IP 地址和主機名 hostname,利用 namespace 進行資源隔離,相當于一臺獨立沙箱環境;

pod 相當于一臺獨立主機,內部可以封裝一個或多個容器(通常是一組相關的容器),內部容器之間訪問采用 localhost。

1.2 pod 用來干什么

通常情況下,在服務部署的時候,使用 pod 來管理一組相關的服務(一個 pod 中要么部署一個服務,要么部署一組有關系的服務)。如下圖是部署了一組有關系的服務的結構圖,其中 C 表示容器(container),下面的 pod 里就有很多個容器。

1c977b52-387a-11ed-ba43-dac502259ad0.png

如何理解一組相關的服務?

如下圖:有一個請求是訪問 Nginx,然后部署了 Nginx 的容器就把請求轉發給部署了 web 服務的容器,web 再訪問數據庫,然后請求會依次返回來數據,最后再返回給用戶。因此在 鏈式調用的調用鏈路上的服務 叫做一組相關的服務。

1ca9d928-387a-11ed-ba43-dac502259ad0.png

1.3 實現 web 服務集群

只需要復制多個 pod 的副本即可,這也是 k8s 管理的先進之處。k8s 如果要進行擴容或縮容,只需要控制 pod 的數量即可。比如上面那個部署模式,服務集群就是復制多個這樣的 pod。

1cb75f44-387a-11ed-ba43-dac502259ad0.png

1.4 pod 底層網絡和數據存儲是如何進行的

前面說過 pod 內部的容器也是一個獨立的沙箱環境,因此也有自己的 ip 和 端口。如果內部容器還是通過 ip:port 來通信,相當于還是遠程訪問,這樣的話性能會受到一定的影響。如何提高內部容器之間訪問的性能呢?

1cd7de0e-387a-11ed-ba43-dac502259ad0.png

pod 底層

pod 內部容器創建之前,必須先創建 pause 容器。pause 有兩個作用:共享網絡和共享存儲。

每個服務容器共享 pause 存儲,不需要自己存儲數據,都交給 pause維護。

pause 也相當于這三個容器的網卡,因此他們之間的訪問可以通過 localhost 方式訪問,相當于訪問本地服務一樣,性能非常高(就像本地幾臺虛擬機之間可以 ping 通)。

2. ReplicaSet 副本控制器

2.1 副本控制器基本理解

作用:管理控制 pod 副本(服務集群)的數量,以使其永遠與預期設定的數量保持一致。例如:replicas = 3 (創建 3 個副本,這是提前設置好的)

1cf0ca0e-387a-11ed-ba43-dac502259ad0.png

當副本設置為 3 時,副本控制器將會永遠保證副本數量為 3。因此當有 pod 服務宕機時(如上面第 3 個 pod),那副本控制器會立馬重新創建一個新的 pod,就能夠保證副本數量一直為預先設定好的 3 個。

2.2 ReplicaSet 和 ReplicationController 的區別

ReplicaSet 和 ReplicationController 都是副本控制器,其中:

相同點:都有前面 2.1 節所描述的功能

不同點:標簽選擇器的功能不同。ReplicaSet 可以使用標簽選擇器進行 單選 和 復合選擇;而 ReplicationController 只支持 單選操作。

什么意思呢?

假設下面有下面兩個不同機器上的 Node 結點,如何知道它們的 pod 其實都是相同的呢?答案是通過標簽。

給每個 pod 打上標簽 ( key=value 格式,如下圖中的 app=web, release=stable,這有兩個選項,相同的pod副本的標簽是一樣的),于是副本控制器可以通過標簽選擇器 seletor 去選擇一組相關的服務。

一旦 selector 和 pod 的標簽匹配上了,就表明這個 pod 是當前這個副本控制器控制的,表明了副本控制器和 pod 的所屬關系。如下圖中 seletor 指定了 app = web 和 release=stable 是復合選擇,要用 ReplicaSet 才能實現若用 ReplicationController 的話只能選擇一個,如只選擇匹配app=web標簽。這樣下面的 3 個 pod 就歸這個副本控制器管。

1d02c948-387a-11ed-ba43-dac502259ad0.png

可見 ReplicaSet 功能更齊全,所以在新版的 k8s 中,建議使用 ReplicaSet 作為副本控制器,不再使用 ReplicationController。

3. Deployment 部署對象

3.1 滾動更新

ReplicaSet 副本控制器可以永久保持 pod 副本的數量。但是項目的需求在不斷的迭代、更新,項目在不斷發版。那如何做到服務更新?難道把服務停掉再把新版本部署上去嗎?當然不是,答案是用滾動更新。就是重新創建一個 pod (v2版本) 來代替 之前的 pod (v1版本)。

1d1d1596-387a-11ed-ba43-dac502259ad0.png

那是如何滾動更新的呢?涉及到下面要講到的部署模型。

3.2 部署模型

單獨的 ReplicaSet 是不支持滾動更新的,Deployment 對象支持滾動更新,通常和 ReplicaSet 一起使用。

需要滾動更新時的步驟:

Deployment 建立新的 Replicaset

Replicaset 重新建立新的 pod

所以它們之間是有層次關系的,Deployment 管 Replicaset,Replicaset 維護 pod。在更新時刪除的是舊的 pod,老版本的 ReplicaSet 是不會刪除的,所以在需要時還可以回退以前的狀態。

4. StatefulSet 部署有狀態服務

4.1 引入定義

思考:如果 MySQL(有狀態服務) 使用容器化部署,會存在什么問題?

1、容器都是有生命周期的,一旦宕機數據就很可能丟失

2、pod 也有生命周期的,用 pod 部署時把 pod 集群副本重啟以后也可能會出現數據丟失

因此對 k8s 來說,不能使用 Deployment 部署有狀態的服務。通常情況下,Deployment 被用來部署無狀態服務。

然后 StatefulSet 就是為了解決有狀態服務使用容器化部署的一個問題。

4.2 如何理解狀態服務

有狀態服務

有實時的數據需要存儲

在有狀態服務集群中,如果把某一個服務抽離出來,一段時間后再加入回集群網絡,此后集群網絡會無法使用

無狀態服務

沒有實時的數據需要存儲

在無狀態服務集群中,如果把某一個服務抽離出去,一段時間后再加入回集群網絡,對集群服務無任何影響,因為它們不需要做交互,不需要數據同步等等。

4.3 部署模型

StatefulSet 的部署模型和 Deployment 的很相似。

比如下圖,借助 PVC(與存儲有關) 文件系統來存儲的實時數據,因此下圖就是一個有狀態服務的部署。

在 pod 宕機之后重新建立 pod 時,StatefulSet 通過保證 hostname 不發生變化來保證數據不丟失。因此 pod 就可以通過 hostname 來關聯(找到) 之前存儲的數據。

1d2cea70-387a-11ed-ba43-dac502259ad0.png

原文鏈接:https://blog.csdn.net/qq_43280818/article/details/10691018

審核編輯 :李倩

聲明:本文內容及配圖由入駐作者撰寫或者入駐合作網站授權轉載。文章觀點僅代表作者本人,不代表電子發燒友網立場。文章及其配圖僅供工程師學習之用,如有內容侵權或者其他違規問題,請聯系本站處理。 舉報投訴
  • 控制器
    +關注

    關注

    112

    文章

    16214

    瀏覽量

    177479
  • 容器
    +關注

    關注

    0

    文章

    494

    瀏覽量

    22046
  • POD
    POD
    +關注

    關注

    0

    文章

    16

    瀏覽量

    6013

原文標題:Kubernetes 核心組件原理梳理,年底加雞腿必看~

文章出處:【微信號:網絡工程師筆記,微信公眾號:網絡工程師筆記】歡迎添加關注!文章轉載請注明出處。

收藏 人收藏

    評論

    相關推薦

    【米爾NXP i.MX 93開發板試用評測】1、異構核心通信的技術內容

    組件,其中兩個是可選的。核心組件位于rpmsg_lite.c。兩個可選組件用于實現阻塞接收API(在rpmsg_queue.c中)和動態\"命名\"端點創建和刪除公告服務(在
    發表于 09-21 20:24

    表面貼裝 TCXO 汽車電子用 DSK321STD:卓越性能,穩定可靠的汽車電子核心組件

    表面貼裝 TCXO(汽車電子用)DSK321STD:卓越性能,穩定可靠的汽車電子核心組件
    的頭像 發表于 08-01 10:22 ?996次閱讀
    表面貼裝 TCXO 汽車電子用 DSK321STD:卓越性能,穩定可靠的汽車電子<b class='flag-5'>核心</b><b class='flag-5'>組件</b>

    工業自動化控制系統的核心組件不包括什么

    工業自動化控制系統是現代工業生產中不可或缺的一部分,它通過計算機、傳感器、執行器等設備實現對生產過程的自動控制和管理。在工業自動化控制系統中,有許多核心組件,它們共同構成了系統的骨架和靈魂。然而
    的頭像 發表于 06-11 10:57 ?526次閱讀

    碩博電子礦用卡車電控系統的核心組件的優勢

    卡車電控系統的核心組件主要包括SPC-SFMC-X3632A控制器與SPC-SDIO-S1212 IO模塊,二者共同構成了系統的“智慧大腦”與“信息樞紐”。 SPC-SFMC-X3632A控制器,作為電控系統的核心處理器,具備強
    的頭像 發表于 04-24 09:52 ?355次閱讀

    半導體品控:打造穩定、可靠的電子核心組件

    半導體,作為現代電子工業的核心組件,其品質控制至關重要。半導體的品控不僅關乎產品的性能穩定,還直接影響著下游電子產品的可靠性和使用壽命。本文將詳細介紹半導體品控的各個環節,以及在整個半導體產業鏈中的重要性。
    的頭像 發表于 04-18 09:51 ?669次閱讀
    半導體品控:打造穩定、可靠的電子<b class='flag-5'>核心</b><b class='flag-5'>組件</b>

    服務器中的CPU核心和線程到底是什么?

    CPU核心作為CPU(中央處理單元)的主要處理單元。該組件從計算機內存中讀取并執行指令。每個核心一次只能運行一項任務,因此具有多個核心的 CPU 可以同時執行多個任務。這對于多任務處理
    的頭像 發表于 03-04 17:09 ?1291次閱讀

    一分鐘了解飛騰COMe核心板GEC-2001-01#主板

    主板核心
    GITSTAR 集特工控
    發布于 :2024年02月02日 13:41:56

    分布式大屏控制系統的核心組件有哪些?

    分布式大屏控制系統的核心組件主要包括以下幾個部分: 信號源處理器(輸入節點):信號源處理器是系統的輸入節點,負責將各種不同的視頻信號(如RGB信號、視頻信號、高清信號、音頻信號等)實時編碼成能夠在
    的頭像 發表于 01-29 14:40 ?502次閱讀
    分布式大屏控制系統的<b class='flag-5'>核心</b><b class='flag-5'>組件</b>有哪些?

    混合專家模型 (MoE)核心組件和訓練方法介紹

    ) 的 Transformer 模型在開源人工智能社區引起了廣泛關注。在本篇博文中,我們將深入探討 MoEs 的核心組件、訓練方法,以及在推理過程中需要考量的各種因素。 讓我們開始吧! 簡短總結 混合專家模型 (MoEs
    的頭像 發表于 01-13 09:37 ?1186次閱讀
    混合專家模型 (MoE)<b class='flag-5'>核心</b><b class='flag-5'>組件</b>和訓練方法介紹

    GCE-2001-01全國產化飛騰D2000八核CoMe主板核心

    主板核心
    GITSTAR 集特工控
    發布于 :2024年01月11日 16:20:11

    基于高通 SDM450平臺研發 —— XY450 4G 核心

    高通核心
    jf_87063710
    發布于 :2024年01月10日 09:32:52

    主軸:機械運動的核心組件?|深圳恒興隆機電a

    的基石。隨著技術的發展,對主軸的設計和材料要求也在不斷提高,以適應更加復雜和精密的機械系統。以上就是深圳市恒興隆機電有限公司小編給您們介紹的主軸:機械運動的核心組件的內容,希望大家看后有所幫助!深圳市
    發表于 01-03 10:10

    物聯網核心板 —— XY8390

    物聯網核心
    jf_87063710
    發布于 :2023年12月19日 11:52:01

    Pod一直處于Pending狀態?什么是Pod拓撲約束?

    起因: 今天在部署組件的時候,發現組件pod一直處于Pending狀態,報錯顯示的原因是:不滿足Pod拓撲分布約束,看了代碼發現是原來同事給組件
    的頭像 發表于 12-18 11:46 ?1165次閱讀
    <b class='flag-5'>Pod</b>一直處于Pending狀態?什么是<b class='flag-5'>Pod</b>拓撲約束?

    中森電子相控陣雷達微波組件及配套核心芯片項目落地灃東

    據西咸新區灃東新城官微消息,近日,西安中森電子科技有限公司(簡稱:中森電子)正式入駐灃東自貿服貿產業園。 據相關負責人介紹,中森電子將在灃東新城投資打造相控陣雷達微波組件及配套核心芯片項目,核心產品
    的頭像 發表于 12-05 17:51 ?518次閱讀