天天看點

K8S自己動手系列 - 2.1 - Pod

說在最前

Pod作為Kubernetes的一等公民,是K8S排程的最小單元,也是使用Kubernetes的人打交道最多的K8S模型。既然Pod這麼重要,搞清楚Pod的各種功能及操作就非常重要了,了解了Pod以後,各種Pod的控制器元件,例如:Deployment,StatefulSet,DaemonSet, Job,ReplicaSet了解起來才能事半功倍。

正篇

閱讀官方文檔對Pod的描述,其闡述了Pod在叢集中的兩種主要使用方式:

  • 一個Pod運作一個容器
  • 一個Pod運作多個需要在一起的容器

由于前面的實驗,我們已經使用過Deployment部署簡單的nginx容器,這種就屬于第一種,一個Pod運作一個容器的模型,是以本篇文章我們來實戰一下,一個Pod運作多個互相關聯的容器。

實戰

場景說明

本文以常用blog應用wordpress+mysql為例,将wordpress與mysql運作在同一個Pod内,并實作同Pod的互相通路。

本文實驗所有的源碼儲存在:

https://github.com/zrbcool/blog-public/tree/master/k8s-hands-on/lab04

建立wordpress的Pod

檢視Pod的yaml定義:

lab04 git:(master) cat 01-wordpress-pod.yaml 
apiVersion: v1
kind: Pod
metadata:
  labels:
    app: wordpress
  name: wordpress 
spec:
  containers:
  - image: wordpress:latest 
    imagePullPolicy: IfNotPresent
    name: wordpress           

部署該Pod,并檢視運作狀态

lab04 kubectl apply -f 01-wordpress-pod.yaml
pod/wordpress create
  lab04 kubectl get pods -o wide
NAME        READY   STATUS    RESTARTS   AGE     IP            NODE       NOMINATED NODE   READINESS GATES
wordpress   1/1     Running   0          2m21s   10.244.0.53   worker01   <none>           <none>
  lab04 http 10.244.0.53 
HTTP/1.1 302 Found
Connection: Keep-Alive
Content-Length: 0
Content-Type: text/html; charset=UTF-8
Date: Mon, 10 Jun 2019 05:37:54 GMT
Keep-Alive: timeout=5, max=100
Location: http://10.244.0.53/wp-admin/setup-config.php
Server: Apache/2.4.25 (Debian)
X-Powered-By: PHP/7.3.6           

為了友善通路,我們再建立一個類型為NodePort的Service(這塊不用糾結,後面會專門講到),

lab04 git:(master) cat 02-wordpress-svc.yaml 
apiVersion: v1
kind: Service
metadata:
  name: wordpress-svc 
  labels:
    app: wordpress
spec:
  ports:
  - port: 80
    protocol: TCP
    targetPort: 80
  selector:
    app: wordpress
  type: NodePort

  lab04 kubectl apply -f 02-wordpress-svc.yaml 
service/wordpress-svc created
  lab04 kubectl get svc wordpress-svc
NAME            TYPE       CLUSTER-IP    EXTERNAL-IP   PORT(S)        AGE
wordpress-svc   NodePort   10.98.40.11   <none>        80:30466/TCP   108s           

然後我們用節點IP:30466就可以進行通路了,試試

K8S自己動手系列 - 2.1 - Pod

加入mysql的Pod

上面的步驟,我們成功使用Pod資源模型部署了wordpress,但是wordpress是基于mysql的應用,我們還需要一個mysql,針對這個實驗,我們将mysql與wordpress部署在一個pod,這樣他們就可以基于localhost進行通信了,來試試看。

修改Pod定義,加入mysql

修改後的yaml請參考:

lab04 git:(master) cat 03-wordpress-mysql-pod.yaml 
apiVersion: v1
kind: Pod
metadata:
  labels:
    app: wordpress
  name: wordpress 
spec:
  containers:
  - image: wordpress:latest 
    imagePullPolicy: IfNotPresent
    name: wordpress
  - image: mysql:5.7.26
    imagePullPolicy: IfNotPresent
    name: mysql
    env:
      - name: MYSQL_ROOT_PASSWORD 
        value: "passw0rd"           

執行部署,

lab04 kubectl delete -f 03-wordpress-mysql-pod.yaml
pod "wordpress" deleted
  lab04 kubectl create -f 03-wordpress-mysql-pod.yaml
pod/wordpress created
  lab04 kubectl get pods -o wide
NAME        READY   STATUS    RESTARTS   AGE   IP            NODE       NOMINATED NODE   READINESS GATES
wordpress   2/2     Running   0          25s   10.244.0.55   worker01   <none>           <none>

  lab04 telnet 10.244.0.55 3306
Trying 10.244.0.55...
Connected to 10.244.0.55.
Escape character is '^]'.

  lab04 http 10.244.0.55
HTTP/1.1 302 Found
Connection: Keep-Alive
Content-Length: 0
Content-Type: text/html; charset=UTF-8
Date: Mon, 10 Jun 2019 06:14:58 GMT
Keep-Alive: timeout=5, max=100
Location: http://10.244.0.55/wp-admin/setup-config.php
Server: Apache/2.4.25 (Debian)
X-Powered-By: PHP/7.3.6           

可見兩個容器已經在同一個Pod内啟動,并且mysql的3306端口也是通的,wordpress的80也是OK的

進入wordpress設定界面進行配置

K8S自己動手系列 - 2.1 - Pod

下一步

K8S自己動手系列 - 2.1 - Pod

上圖說了,缺資料庫,來手工建立一個庫

lab04 kubectl get pods -o wide
NAME        READY   STATUS    RESTARTS   AGE     IP            NODE       NOMINATED NODE   READINESS GATES
wordpress   2/2     Running   0          5m40s   10.244.0.57   worker01   <none>           <none>
  lab04 docker run -it --network host --rm mysql mysql -h10.244.0.57 -uroot -p
Enter password: 
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 3
Server version: 5.7.26 MySQL Community Server (GPL)

Copyright (c) 2000, 2019, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql> create database wordpress;
Query OK, 1 row affected (0.00 sec)           

再來一次,成功了!

K8S自己動手系列 - 2.1 - Pod

通過标簽過濾,檢視下本次實驗我們建立的所有資源:

lab04 git:(master) kubectl get all -l app=wordpress
NAME            READY   STATUS    RESTARTS   AGE
pod/wordpress   2/2     Running   0          29m

NAME                    TYPE       CLUSTER-IP    EXTERNAL-IP   PORT(S)        AGE
service/wordpress-svc   NodePort   10.98.40.11   <none>        80:30466/TCP   67m           

總結

我們通過定義Pod,将兩個容器定義在一個Pod當中,啟動了wordpress+mysql的一個Pod執行個體,并使用NodePort類型的Service對wordpress進行了設定及通路,成功實踐了一Pod多容器的使用方式。

或許你已經想到了目前這個實驗結果的問題:

  • 1,mysql的資料是狀态化資料需要儲存
  • 2,直接定義的Pod是無法進行修改,擴容的,隻能删除重建

    這些問題,我們後面使用到的StatefulSet及Deployment等可以解決。

繼續閱讀