那曲檬骨新材料有限公司

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

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

3天內(nèi)不再提示

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

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

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

1.1 pod 是什么

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

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

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

1.2 pod 用來干什么

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

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

如何理解一組相關(guān)的服務(wù)?

如下圖:有一個請求是訪問 Nginx,然后部署了 Nginx 的容器就把請求轉(zhuǎn)發(fā)給部署了 web 服務(wù)的容器,web 再訪問數(shù)據(jù)庫,然后請求會依次返回來數(shù)據(jù),最后再返回給用戶。因此在 鏈式調(diào)用的調(diào)用鏈路上的服務(wù) 叫做一組相關(guān)的服務(wù)。

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

1.3 實現(xiàn) web 服務(wù)集群

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

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

1.4 pod 底層網(wǎng)絡(luò)和數(shù)據(jù)存儲是如何進行的

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

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

pod 底層

pod 內(nèi)部容器創(chuàng)建之前,必須先創(chuàng)建 pause 容器。pause 有兩個作用:共享網(wǎng)絡(luò)和共享存儲。

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

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

2. ReplicaSet 副本控制器

2.1 副本控制器基本理解

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

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

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

2.2 ReplicaSet 和 ReplicationController 的區(qū)別

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

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

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

什么意思呢?

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

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

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

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

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

3. Deployment 部署對象

3.1 滾動更新

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

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

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

3.2 部署模型

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

需要滾動更新時的步驟:

Deployment 建立新的 Replicaset

Replicaset 重新建立新的 pod

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

4. StatefulSet 部署有狀態(tài)服務(wù)

4.1 引入定義

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

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

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

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

然后 StatefulSet 就是為了解決有狀態(tài)服務(wù)使用容器化部署的一個問題。

4.2 如何理解狀態(tài)服務(wù)

有狀態(tài)服務(wù)

有實時的數(shù)據(jù)需要存儲

在有狀態(tài)服務(wù)集群中,如果把某一個服務(wù)抽離出來,一段時間后再加入回集群網(wǎng)絡(luò),此后集群網(wǎng)絡(luò)會無法使用

無狀態(tài)服務(wù)

沒有實時的數(shù)據(jù)需要存儲

在無狀態(tài)服務(wù)集群中,如果把某一個服務(wù)抽離出去,一段時間后再加入回集群網(wǎng)絡(luò),對集群服務(wù)無任何影響,因為它們不需要做交互,不需要數(shù)據(jù)同步等等。

4.3 部署模型

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

比如下圖,借助 PVC(與存儲有關(guān)) 文件系統(tǒng)來存儲的實時數(shù)據(jù),因此下圖就是一個有狀態(tài)服務(wù)的部署。

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

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

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

審核編輯 :李倩

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

    關(guān)注

    112

    文章

    16448

    瀏覽量

    179481
  • 容器
    +關(guān)注

    關(guān)注

    0

    文章

    499

    瀏覽量

    22125
  • POD
    POD
    +關(guān)注

    關(guān)注

    0

    文章

    18

    瀏覽量

    6050

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

文章出處:【微信號:網(wǎng)絡(luò)工程師筆記,微信公眾號:網(wǎng)絡(luò)工程師筆記】歡迎添加關(guān)注!文章轉(zhuǎn)載請注明出處。

收藏 人收藏

    評論

    相關(guān)推薦

    通信基站核心組件TNC插頭,為何不可或缺?

    德索工程師說道在通信技術(shù)日新月異的當下,通信基站作為現(xiàn)代通信網(wǎng)絡(luò)的神經(jīng)中樞,承載著人們?nèi)粘Mㄔ?、暢快上網(wǎng)等各類通信需求。在通信基站紛繁復雜的組件體系中,TNC插頭猶如一顆關(guān)鍵螺絲釘,看似渺小,卻發(fā)揮著無可替代的重要作用,其核心價值主要體現(xiàn)在以下幾個維度。
    的頭像 發(fā)表于 01-23 10:25 ?91次閱讀
    通信基站<b class='flag-5'>核心</b><b class='flag-5'>組件</b>TNC插頭,為何不可或缺?

    天問ASRPRO核心板+ESP32S3#pcb設(shè)計

    核心
    默語聆聽
    發(fā)布于 :2025年01月13日 00:51:48

    為什么要選擇BGA核心板?

    導讀M3562核心板不僅在性能上表現(xiàn)卓越,還采用了先進的BGA封裝技術(shù)。那么,BGA封裝核心板究竟有哪些獨特的優(yōu)勢呢?本文將帶您深入探討。繼MX2000和CPMG2ULBGA核心板之后,ZLG致遠
    的頭像 發(fā)表于 01-07 11:36 ?223次閱讀
    為什么要選擇BGA<b class='flag-5'>核心</b>板?

    MT8788安卓核心板_MTK8788核心板參數(shù)_聯(lián)發(fā)科MTK核心

    MT8788安卓核心板是一款小巧而強大的開發(fā)平臺,其尺寸僅為52.5mm x 38.5mm x 2.95mm。該核心板集成了多種電路組件,包括處理器、GPU、LPDDR3存儲器、eMMC閃存及電源
    的頭像 發(fā)表于 01-03 20:06 ?223次閱讀
    MT8788安卓<b class='flag-5'>核心</b>板_MTK8788<b class='flag-5'>核心</b>板參數(shù)_聯(lián)發(fā)科MTK<b class='flag-5'>核心</b>板

    國產(chǎn)飛騰核心板,性能強勁,支持二次開發(fā)

    核心
    gnhpc
    發(fā)布于 :2024年12月27日 16:19:19

    驍龍665安卓核心板_SM6125核心板參數(shù)_安卓核心板高通方案定制

    驍龍665(SM6125)核心板是一款先進的智能模塊,搭載了多種網(wǎng)絡(luò)制式的LTE Cat 4模塊,旨在滿足現(xiàn)代化通訊需求。這款核心板基于64位架構(gòu),采用三星11納米工藝技術(shù)制造,配備了八核CPU
    的頭像 發(fā)表于 11-13 20:17 ?777次閱讀
    驍龍665安卓<b class='flag-5'>核心</b>板_SM6125<b class='flag-5'>核心</b>板參數(shù)_安卓<b class='flag-5'>核心</b>板高通方案定制

    深度解析linux HID核心

    在linux內(nèi)核中,HID核心是完成HID功能的關(guān)鍵組件,如果內(nèi)核支持HID,在啟動過程中,則會對HID進行初始化,完成該操作的函數(shù)是hid_init(),實現(xiàn)在/drivers/hid/hid-core.c中。
    的頭像 發(fā)表于 09-29 17:04 ?623次閱讀
    深度解析linux HID<b class='flag-5'>核心</b>

    【米爾NXP i.MX 93開發(fā)板試用評測】1、異構(gòu)核心通信的技術(shù)內(nèi)容

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

    混聯(lián)式混合動力汽車核心組件介紹

    混聯(lián)式驅(qū)動系統(tǒng)融合了串聯(lián)式與并聯(lián)式的技術(shù)特點,其構(gòu)成如下圖所示: 核心組件包括發(fā)動機、發(fā)電機、功率轉(zhuǎn)換器、電機控制器、驅(qū)動電機、動力耦合器以及動力電池系統(tǒng)等。 發(fā)動機輸出的能量一部分通過機械鏈接直接
    的頭像 發(fā)表于 08-13 18:16 ?1142次閱讀
    混聯(lián)式混合動力汽車<b class='flag-5'>核心</b><b class='flag-5'>組件</b>介紹

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

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

    工業(yè)自動化控制系統(tǒng)的核心組件不包括什么

    工業(yè)自動化控制系統(tǒng)是現(xiàn)代工業(yè)生產(chǎn)中不可或缺的一部分,它通過計算機、傳感器、執(zhí)行器等設(shè)備實現(xiàn)對生產(chǎn)過程的自動控制和管理。在工業(yè)自動化控制系統(tǒng)中,有許多核心組件,它們共同構(gòu)成了系統(tǒng)的骨架和靈魂。然而
    的頭像 發(fā)表于 06-11 10:57 ?671次閱讀

    國產(chǎn)FPGA核心板!米爾紫光同創(chuàng)Logos-2和Xilinx Artix-7核心

    隨著嵌入式的快速發(fā)展,在工控、通信、5G通信領(lǐng)域,F(xiàn)PGA以其超靈活的可編程能力,被越來越多的工程師選擇。近日,米爾電子發(fā)布2款FPGA的核心板和開發(fā)板,型號分別為:基于紫光同創(chuàng)Logos-2系列
    發(fā)表于 05-31 17:40

    碩博電子礦用卡車電控系統(tǒng)的核心組件的優(yōu)勢

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

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

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

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

    CPU核心作為CPU(中央處理單元)的主要處理單元。該組件從計算機內(nèi)存中讀取并執(zhí)行指令。每個核心一次只能運行一項任務(wù),因此具有多個核心的 CPU 可以同時執(zhí)行多個任務(wù)。這對于多任務(wù)處理
    的頭像 發(fā)表于 03-04 17:09 ?1499次閱讀
    网上百家乐是现场吗| 万州区| 永利高百家乐官网进不去| 丰顺县| 必博百家乐游戏| 香港六合彩官方网| 24山向名| 网上真钱赌博| 百家乐的嬴钱法| 六合彩报码室| 爱拼百家乐现金网| 百家乐官网庄闲的冷热| 百家乐桌子轮盘| 澳门百家乐官网真人娱乐城| 功夫百家乐的玩法技巧和规则| 百家乐官网前四手下注之观点| 大发888大发888官网| 新锦江百家乐官网娱乐场开户注册 | 网上的百家乐官网怎么才能赚钱| 大发888娱乐城登陆| 百家乐技巧阅读| 波浪百家乐官网测试| 大发888怎么了| 百家乐开户博彩论坛| 百家乐官网庄闲客户端| 利好国际| 全讯网找a3322.com| 百家乐官网技巧经| 百家乐官网高手论坮| 全讯网跑狗图| 玩百家乐有何技巧| 网络百家乐游赌博| 大发百家乐游戏| 速博网上娱乐| 百博百家乐的玩法技巧和规则 | 百家乐官网扑克多少张| 百家乐官网网站哪个好| 尚志市| 申城棋牌网| 老虎机价格| 百家乐闲和庄|