通過 Service 訪問 Pod - 每天5分鐘玩轉 Docker 容器技術(136)

暖夏未眠丶發表於2018-03-02

摘要:
Kubernets 通過 Service 訪問 Pod。本節我們開始學習 Service。

本節開始學習 Service。
我們不應該期望 Kubernetes Pod 是健壯的,而是要假設 Pod 中的容器很可能因為各種原因發生故障而死掉。Deployment 等 controller 會通過動態建立和銷燬 Pod 來保證應用整體的健壯性。換句話說,Pod 是脆弱的,但應用是健壯的。

每個 Pod 都有自己的 IP 地址。當 controller 用新 Pod 替代發生故障的 Pod 時,新 Pod 會分配到新的 IP 地址。這樣就產生了一個問題:

如果一組 Pod 對外提供服務(比如 HTTP),它們的 IP 很有可能發生變化,那麼客戶端如何找到並訪問這個服務呢?

Kubernetes 給出的解決方案是 Service。

建立 Service

Kubernetes Service 從邏輯上代表了一組 Pod,具體是哪些 Pod 則是由 label 來挑選。Service 有自己 IP,而且這個 IP 是不變的。客戶端只需要訪問 Service 的 IP,Kubernetes 則負責建立和維護 Service 與 Pod 的對映關係。無論後端 Pod 如何變化,對客戶端不會有任何影響,因為 Service 沒有變。

來看個例子,建立下面的這個 Deployment:

我們啟動了三個 Pod,執行 httpd 映象,label 是 run: httpd,Service 將會用這個 label 來挑選 Pod。

Pod 分配了各自的 IP,這些 IP 只能被 Kubernetes Cluster 中的容器和節點訪問。

接下來建立 Service,其配置檔案如下:

v1 是 Service 的 apiVersion

② 指明當前資源的型別為 Service

③ Service 的名字為 httpd-svc

selector 指明挑選那些 label 為 run: httpd 的 Pod 作為 Service 的後端。

⑤ 將 Service 的 8080 埠對映到 Pod 的 80 埠,使用 TCP 協議。

執行 kubectl apply 建立 Service httpd-svc

httpd-svc 分配到一個 CLUSTER-IP 10.99.229.179。可以通過該 IP 訪問後端的 httpd Pod。

根據前面的埠對映,這裡要使用 8080 埠。另外,除了我們建立的 httpd-svc,還有一個 Service kubernetes,Cluster 內部通過這個 Service 訪問 kubernetes API Server。

通過 kubectl describe 可以檢視 httpd-svc 與 Pod 的對應關係。

Endpoints 羅列了三個 Pod 的 IP 和埠。我們知道 Pod 的 IP 是在容器中配置的,那麼 Service 的 Cluster IP 又是配置在哪裡的呢?CLUSTER-IP 又是如何對映到 Pod IP 的呢?

答案是 iptables,我們下節討論。

書籍:
1.《每天5分鐘玩轉Docker容器技術》
item.jd.com/16936307278…

2.《每天5分鐘玩轉OpenStack》
item.jd.com/12086376.ht…

版權宣告:本文內容由網際網路使用者自發貢獻,版權歸作者所有,本社群不擁有所有權,也不承擔相關法律責任。如果您發現本社群中有涉嫌抄襲的內容,歡迎傳送郵件至:yqgroup@service.aliyun.com 進行舉報,並提供相關證據,一經查實,本社群將立刻刪除涉嫌侵權內容。
通過 Service 訪問 Pod - 每天5分鐘玩轉 Docker 容器技術(136)

用雲棲社群APP,舒服~

原文連結


相關文章