通俗理解?Kubernetes?中的服務(wù),搞懂后真“有趣”
[導(dǎo)讀]1.復(fù)習(xí)pod相關(guān)核心結(jié)構(gòu)1.1pod結(jié)構(gòu)pod相當(dāng)于一個(gè)容器,pod有獨(dú)立的ip地址,也有自己的hostname,利用namespace進(jìn)行資源隔離,相當(dāng)于一個(gè)獨(dú)立沙箱環(huán)境。pod內(nèi)部封裝的是容器,可以封裝一個(gè),或者多個(gè)容器(通常是一組相關(guān)的容器)1.2pod網(wǎng)絡(luò)pod有自己獨(dú)...
1. 復(fù)習(xí) pod 相關(guān)核心結(jié)構(gòu)
1.1 pod 結(jié)構(gòu)
- pod 相當(dāng)于一個(gè)容器,pod 有獨(dú)立的 ip 地址,也有自己的 hostname,利用 namespace 進(jìn)行資源隔離,相當(dāng)于一個(gè)獨(dú)立沙箱環(huán)境。
- pod 內(nèi)部封裝的是容器,可以封裝一個(gè),或者多個(gè)容器(通常是一組相關(guān)的容器)
1.2 pod 網(wǎng)絡(luò)
-
pod 有自己獨(dú)立的 IP 地址
-
pod 內(nèi)部的容器之間是通過(guò) localhost 進(jìn)行訪問(wèn)
2. pod 如何對(duì)外提供訪問(wèn)
首先 pod 有自己的 IP 和 hostname,但 pod 是虛擬的資源對(duì)象 (在計(jì)算機(jī)中表現(xiàn)為進(jìn)程),沒有對(duì)應(yīng)實(shí)體 (物理機(jī),物理網(wǎng)卡) 與之對(duì)應(yīng),所以是無(wú)法直接對(duì)外提供服務(wù)訪問(wèn)的。因此如果 pod 想對(duì)外提供服務(wù),必須綁定物理機(jī)端口 (即在物理機(jī)上開啟端口,讓這個(gè)端口和 pod 的端口進(jìn)行映射),這樣就可以通過(guò)物理機(jī)進(jìn)行數(shù)據(jù)包的轉(zhuǎn)發(fā)。下面以一臺(tái) Linux 系統(tǒng)的機(jī)器為例子( logstash 是做日志收集用的)
3. pod 的負(fù)載均衡
很關(guān)鍵的一個(gè)問(wèn)題:一組相關(guān)的 pod 副本,如何實(shí)現(xiàn)訪問(wèn)負(fù)載均衡?就如當(dāng)請(qǐng)求達(dá)到,請(qǐng)求轉(zhuǎn)發(fā)給哪個(gè) pod 比較好?一個(gè)想法就是用 pod 再部署一個(gè) Nginx。舉例:如下圖,注意下圖右邊的 Node 里面有兩個(gè)是 支付 服務(wù),與訂單服務(wù)的是不同類型的 pod。如果一個(gè)請(qǐng)求訂單的服務(wù)發(fā)來(lái)上面那個(gè) Nginx,那這個(gè) pod 可以有 4 條轉(zhuǎn)發(fā)路線,可以想到用 hash 呀什么的把不同請(qǐng)求映射到不同的 pod 去轉(zhuǎn)發(fā)。但能不能這么做呢?
3.1 什么是 Service 資源對(duì)象
- POD IP:pod 的 IP 地址
- NODE IP:物理機(jī)的 IP 地址
- cluster IP:虛擬 IP,是由 kubernetes 抽象出的 service 對(duì)象,這個(gè) service 對(duì)象就是一個(gè) VIP (virtual IP, VIP) 的資源對(duì)象
3.2 service 如何實(shí)現(xiàn)負(fù)載均衡
例如現(xiàn)在要負(fù)載均衡地訪問(wèn)一組相同的服務(wù)副本——訂單,這時(shí)就要去做一個(gè) service,對(duì)外表現(xiàn)出是一個(gè)進(jìn)程或資源對(duì)象,有虛擬的 IP (VIP) 和端口。請(qǐng)求會(huì)訪問(wèn) service,然后 service 自己會(huì) 負(fù)載均衡 地發(fā)送給相應(yīng)服務(wù)的 POD,也就是下圖中 4 個(gè)相同的 pod。
3.3 深入 service VIP
- service 和 pod 都是一個(gè)進(jìn)程,都是虛擬的,因此實(shí)際上 service 也不能對(duì)外網(wǎng)提供服務(wù)
- service 和 pod 之間可以直接進(jìn)行通信,它們的通信屬于局域網(wǎng)通信
- 負(fù)載策略:把請(qǐng)求交給 service 后,service 使用 iptables,ipvs 來(lái)實(shí)現(xiàn)數(shù)據(jù)包的分發(fā)