自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Kubernetes 有狀態(tài)應用基本概念&Nginx部署

運維 系統(tǒng)運維
使用無頭服務 Headless Service(相比普通Service只是將spec.clusterIP定義為None,也就是沒有clusterIP,使用endport 來通信)來維護Pod網(wǎng)絡身份,會為每個Pod分配一個數(shù)字編號并且按照編號順序部署。

[[432715]]

1、無狀態(tài)與有狀態(tài)

Deployment控制器設計原則:管理的所有Pod一模一樣,提供同一個服務,也不考慮在哪臺Node運行,可隨意擴容和縮容。這種應用稱為“無狀態(tài)”,例如Web服務

但是,在實際的場景中,并不能滿足所有應用,尤其是分布式應用,會部署多個實例,這些實例之間往往有依賴關(guān)系,例如主從關(guān)系、主備關(guān)系,這種應用稱為“有狀態(tài)”,例如MySQL主從、Etcd集群、redis-cluster 等等

2、StatefulSet 控制器概述

StatefulSet控制器用于部署有狀態(tài)應用,滿足一些有狀態(tài)應用的需求:

  • Pod有序的部署、擴容、刪除和停止
  •  Pod分配一個穩(wěn)定的且唯一的網(wǎng)絡標識
  •  Pod分配一個獨享的存儲

3、StatefulSet 控制器:網(wǎng)絡標識

穩(wěn)定的網(wǎng)絡標識:

使用無頭服務 Headless Service(相比普通Service只是將spec.clusterIP定義為None,也就是沒有clusterIP,使用endport 來通信)來維護Pod網(wǎng)絡身份,會為每個Pod分配一個數(shù)字編號并且按照編號順序部署。還需要在StatefulSet添加serviceName: “nginx”字段指定StatefulSet控制器要使用這個Headless Service。

穩(wěn)定主要體現(xiàn)在主機名和Pod A記錄:

  • 主機名:<statefulset名稱>-<編號>
  • Pod DNS A記錄:<statefulset名稱-編號>.<service-name> .<namespace>.svc.cluster.local (POD 之間通過DNS A 記錄通信)

例如: web-0.web.default.svc.cluster.local

  1. 備注: 
  2.  
  3. A記錄: 將域名指向一個IPv4地址(例如:100.100.100.100),需要增加A記錄 
  4. CNAME記錄: 如果將域名指向一個域名,實現(xiàn)與被指向域名相同的訪問效果,需要增加CNAME記錄。這個域名一般是主機服務商提供的一個域名 
  5. MX記錄: 建立電子郵箱服務,將指向郵件服務器地址,需要設置MX記錄。建立郵箱時,一般會根據(jù)郵箱服務商提供的MX記錄填寫此記錄 
  6. NS記錄: 域名解析服務器記錄,如果要將子域名指定某個域名服務器來解析,需要設置NS記錄 
  7. TXT記錄: 可任意填寫,可為空。一般做一些驗證記錄時會使用此項,如:做SPF(反垃圾郵件)記錄 
  8. AAAA記錄: 將主機名(或域名)指向一個IPv6地址(例如:ff03:0:0:0:0:0:0:c1),需要添加AAAA記錄 

案例:

通過創(chuàng)建一個 nginx 應用的statefluset 控制器

創(chuàng)建 Headless Service ,定義 clusterIP: None (表示K8S 不會在給這個service 去頒發(fā)一個clusterIP 了;相比 deployment 控制器 的每個POD 都是相同的,而 statefuset 控制器的每個POD 都是有狀態(tài)的

需要單獨去訪問 )

  1. [root@master-1 statefulset]# vim service.yaml  
  2. apiVersion: v1 
  3. kind: Service 
  4. metadata: 
  5.   name: web 
  6. spec: 
  7.   clusterIP: None 
  8.   ports: 
  9.   - protocol: TCP 
  10.     port: 80 
  11.   selector: 
  12.     app: nginx 
  13.  
  14. [root@master-1 statefulset]# kubectl apply -f service.yaml  
  15.  
  16. [root@master-1 statefulset]# kubectl get service 
  17. NAME         TYPE        CLUSTER-IP   EXTERNAL-IP   PORT(S)   AGE 
  18. web          ClusterIP   None         <none>        80/TCP    8m18s 

#創(chuàng)建statefulset,指定serviceName

  1. [root@master-1 statefulset]# cat statefulset.yaml  
  2. apiVersion: apps/v1 
  3. kind: StatefulSet 
  4. metadata: 
  5.   name: web 
  6. spec: 
  7.   serviceName: "web" 
  8.   replicas: 3  
  9.   selector: 
  10.     matchLabels: 
  11.       app: nginx  
  12.   template: 
  13.     metadata: 
  14.       labels: 
  15.         app: nginx 
  16.     spec: 
  17.       containers: 
  18.       - name: nginx 
  19.         image: nginx  
  20.         ports: 
  21.         - containerPort: 80 
  22.           name: web 
  23.            
  24.  
  25. [root@master-1 statefulset]# kubectl apply -f statefulset.yaml 
  26. statefulset.apps/web created 
  27.  
  28.  
  29. #發(fā)現(xiàn)pod名稱 帶有序號 
  30. [root@master-1 statefulset]# kubectl get pods 
  31. NAME    READY   STATUS    RESTARTS   AGE 
  32. web-0   1/1     Running   0          16s 
  33. web-1   1/1     Running   0          13s 
  34. web-2   1/1     Running   0          6s 
  35.  
  36.  
  37.  
  38.  
  39. #查了POD的主機名 
  40. 主機名 默認與 POD 名一致,即使POD 飄逸到其他node 上 或者刪除后重建  主機名 都是和POD  名一致。有個穩(wěn)定的主機名 
  41.  
  42.  
  43. [root@master-1 statefulset]# kubectl exec -it web-0 -- hostname 
  44. web-0 
  45. [root@master-1 statefulset]# kubectl exec -it web-1 -- hostname 
  46. web-1 
  47. [root@master-1 statefulset]# kubectl exec -it web-2 -- hostname 
  48. web-2 
  49.  
  50.  
  51.  
  52. #臨時啟動一個busybox pod ,測試dns 解析(注意這里的busybox版本為1.28.4 最新版的busybox nslookup 會有問題) 
  53. [root@master-1 statefulset]# kubectl run -it dns-test --rm --image=busybox:1.28.4 -- sh 
  54. / # nslookup web 
  55. Server:    10.0.0.2 
  56. Address 1: 10.0.0.2 kube-dns.kube-system.svc.cluster.local 
  57.  
  58. Name:      web 
  59. Address 1: 10.244.2.114 web-2.web.default.svc.cluster.local 
  60. Address 2: 10.244.2.113 web-0.web.default.svc.cluster.local 
  61. Address 3: 10.244.1.65 web-1.web.default.svc.cluster.local 
  62.  
  63.  
  64. 可以看到解析出3條記錄出來,解析出對應的三個Pod IP記錄,其他Pod可使用這個名稱訪問 
  65.  
  66.  
  67. 模擬測試刪除這些 pod ,升級鏡像版本,發(fā)現(xiàn)pod ip雖然發(fā)生變化,但是 主機名,Pod DNS A記錄 不會發(fā)生變化 
  68. / # nslookup web 
  69. Server:    10.0.0.2 
  70. Address 1: 10.0.0.2 kube-dns.kube-system.svc.cluster.local 
  71.  
  72. Name:      web 
  73. Address 1: 10.244.2.116 web-2.web.default.svc.cluster.local 
  74. Address 2: 10.244.2.115 web-0.web.default.svc.cluster.local 
  75. Address 3: 10.244.1.66  web-1.web.default.svc.cluster.local 

這個就驗證了 statefulset 的 Pod是 有序的部署、擴容、刪除和停止 且 給每一個POD 分配一個穩(wěn)定的且唯一的網(wǎng)絡標識

4、StatefulSet 控制器:獨享存儲

獨享存儲:StatefulSet的存儲卷使用VolumeClaimTemplate創(chuàng)建,稱為卷申請模板,當StatefulSet使用VolumeClaimTemplate創(chuàng)建一個PersistentVolume時,

同樣也會為每個Pod分配并創(chuàng)建一個編號的PVC,每個PVC綁定對應的PV,從而保證每個Pod都擁有獨立的存儲。

在創(chuàng)建StatefulSet 控制器 獨享存儲前,需要先定義好存儲卷,使用pv 作為持久化存儲卷,后端存儲為NFS

這里采用動態(tài)PV 的方式(NFS server 搭建的過程省略)

一、部署NFS服務器

  1. #服務器安裝nfs服務,提供nfs存儲功能 
  2. 1、安裝nfs-utils 
  3. yum install nfs-utils (centos) 
  4. 或者  apt-get install nfs-kernel-server (ubuntu) 
  5.  
  6. 2、啟動服務 
  7. systemctl enable nfs-server 
  8. systemctl start nfs-server 
  9.  
  10. 3、創(chuàng)建共享目錄完成共享配置 
  11. mkdir /home/nfs   #創(chuàng)建共享目錄 
  12.  
  13. 4、編輯共享配置 
  14. vim /etc/exports                                            
  15. #語法格式:    共享文件路徑     客戶機地址(權(quán)限)     #這里的客戶機地址可以是IP,網(wǎng)段,域名,也可以是任意* 
  16. /home/nfs  *(rw,async,no_root_squash) 
  1. 服務自檢命令  
  2. exportfs -arv 
  3.  
  4.  
  5. 5、重啟服務 
  6. systemctl restart nfs-server 
  7.  
  8.  
  9. 6、本機查看nfs 共享目錄 
  10. #showmount -e 服務器IP地址 (如果提示命令不存在,則需要yum install showmount) 
  11.  
  12. showmount -e 127.0.0.1 
  13. /home/nfs/nginx * 
  14.  
  15.  
  16.  
  17. 7、客戶端模擬掛載[所有k8s的節(jié)點都需要安裝客戶端] 
  18. [root@master-1 ~]# yum install nfs-utils (centos) 
  19. 或者  apt-get install nfs-common (ubuntu) 
  20. [root@master-1 ~]# mkdir /test 
  21. [root@master-1 ~]# mount -t nfs 172.16.201.209:/home/nfs /test 
  22.  
  23. #取消掛載 
  24. [root@master-1 ~]# umount /test 

二、配置PV 動態(tài)供給(NFS StorageClass),創(chuàng)建pvc

#部署NFS實現(xiàn)自動創(chuàng)建PV插件: 一共設計到4個yaml 文件 ,官方的文檔有詳細的說明

https://github.com/kubernetes-incubator/external-storage

Kubernetes 有狀態(tài)應用基本概念&Nginx部署
Kubernetes 有狀態(tài)應用基本概念&Nginx部署
  1. root@k8s-master1:~ # mkdir  /root/pvc 
  2. root@k8s-master1:~ # cd   /root/pvc 

創(chuàng)建rbac.yaml 文件

  1. root@k8s-master1:pvc # cat rbac.yaml  
  2. kind: ServiceAccount 
  3. apiVersion: v1 
  4. metadata: 
  5.   name: nfs-client-provisioner 
  6. --- 
  7. kind: ClusterRole 
  8. apiVersion: rbac.authorization.k8s.io/v1 
  9. metadata: 
  10.   name: nfs-client-provisioner-runner 
  11. rules: 
  12.   - apiGroups: [""
  13.     resources: ["persistentvolumes"
  14.     verbs: ["get""list""watch""create""delete"
  15.   - apiGroups: [""
  16.     resources: ["persistentvolumeclaims"
  17.     verbs: ["get""list""watch""update"
  18.   - apiGroups: ["storage.k8s.io"
  19.     resources: ["storageclasses"
  20.     verbs: ["get""list""watch"
  21.   - apiGroups: [""
  22.     resources: ["events"
  23.     verbs: ["create""update""patch"
  24. --- 
  25. kind: ClusterRoleBinding 
  26. apiVersion: rbac.authorization.k8s.io/v1 
  27. metadata: 
  28.   name: run-nfs-client-provisioner 
  29. subjects: 
  30.   - kind: ServiceAccount 
  31.     name: nfs-client-provisioner 
  32.     namespace: default 
  33. roleRef: 
  34.   kind: ClusterRole 
  35.   name: nfs-client-provisioner-runner 
  36.   apiGroup: rbac.authorization.k8s.io 
  37. --- 
  38. kind: Role 
  39. apiVersion: rbac.authorization.k8s.io/v1 
  40. metadata: 
  41.   name: leader-locking-nfs-client-provisioner 
  42. rules: 
  43.   - apiGroups: [""
  44.     resources: ["endpoints"
  45.     verbs: ["get""list""watch""create""update""patch"
  46. --- 
  47. kind: RoleBinding 
  48. apiVersion: rbac.authorization.k8s.io/v1 
  49. metadata: 
  50.   name: leader-locking-nfs-client-provisioner 
  51. subjects: 
  52.   - kind: ServiceAccount 
  53.     name: nfs-client-provisioner 
  54.     # replace with namespace where provisioner is deployed 
  55.     namespace: default 
  56. roleRef: 
  57.   kind: Role 
  58.   name: leader-locking-nfs-client-provisioner 
  59.   apiGroup: rbac.authorization.k8s.io 

創(chuàng)建deployment.yaml 文件

#官方默認的鏡像地址,國內(nèi)可能無法下載,可以使用 image:

fxkjnj/nfs-client-provisioner:latest

#定義NFS 服務器的地址,共享目錄名稱

  1. root@k8s-master1:pvc # cat deployment.yaml  
  2. apiVersion: v1 
  3. kind: ServiceAccount 
  4. metadata: 
  5.   name: nfs-client-provisioner 
  6. --- 
  7. kind: Deployment 
  8. apiVersion: apps/v1  
  9. metadata: 
  10.   name: nfs-client-provisioner 
  11. spec: 
  12.   replicas: 1 
  13.   strategy: 
  14.     type: Recreate 
  15.   selector: 
  16.     matchLabels: 
  17.       app: nfs-client-provisioner 
  18.   template: 
  19.     metadata: 
  20.       labels: 
  21.         app: nfs-client-provisioner 
  22.     spec: 
  23.       serviceAccountName: nfs-client-provisioner 
  24.       containers: 
  25.         - name: nfs-client-provisioner 
  26.           image: fxkjnj/nfs-client-provisioner:latest 
  27.           volumeMounts: 
  28.             - name: nfs-client-root 
  29.               mountPath: /persistentvolumes 
  30.           env: 
  31.             - name: PROVISIONER_NAME 
  32.               value: fuseim.pri/ifs 
  33.             - name: NFS_SERVER 
  34.               value: 172.16.201.209  
  35.             - name: NFS_PATH 
  36.               value: /home/nfs 
  37.       volumes: 
  38.         - name: nfs-client-root 
  39.           nfs: 
  40.             server: 172.16.201.209 
  41.             path: /home/nfs 

 創(chuàng)建class.yaml

# archiveOnDelete: "true" 表示當PVC 刪除后,后端數(shù)據(jù)不直接刪除,而是歸檔

  1. root@k8s-master1:pvc # cat class.yaml  
  2. apiVersion: storage.k8s.io/v1 
  3. kind: StorageClass 
  4. metadata: 
  5.   name: managed-nfs-storage 
  6. provisioner: fuseim.pri/ifs # or choose another name, must match deployment's env PROVISIONER_NAME' 
  7. parameters: 
  8.   archiveOnDelete: "true" 

 查看存儲類

  1. root@k8s-master1:~/kubernetes/redis# kubectl get sc 
  2. NAME                  PROVISIONER      RECLAIMPOLICY   VOLUMEBINDINGMODE   ALLOWVOLUMEEXPANSION   AGE 
  3. managed-nfs-storage   fuseim.pri/ifs   Delete          Immediate           false                  6s 

基于上面的內(nèi)容創(chuàng)建 statefulset.yaml 文件

  1. root@k8s-master1:~ # mkdir /root/statefulset 
  2. root@k8s-master1:~ # cd  /root/statefulset 
  3. root@k8s-master1:statefulset # vim  statefulset.yaml 
  4. apiVersion: apps/v1 
  5. kind: StatefulSet 
  6. metadata: 
  7.   name: web 
  8. spec: 
  9.   serviceName: "web" 
  10.   replicas: 3  
  11.   selector: 
  12.     matchLabels: 
  13.       app: nginx  
  14.   template: 
  15.     metadata: 
  16.       labels: 
  17.         app: nginx 
  18.     spec: 
  19.       containers: 
  20.       - name: nginx 
  21.         image: nginx:1.16  
  22.         ports: 
  23.         - containerPort: 80 
  24.           name: web 
  25.         volumeMounts: 
  26.         - name: nginx-pvc       #指定PVC名稱 
  27.           mountPath: /usr/share/nginx/html 
  28.   volumeClaimTemplates:     #相當于pvc模板 
  29.   - metadata: 
  30.       name: nginx-pvc           #創(chuàng)建的PVC名稱 
  31.     spec: 
  32.       storageClassName: "managed-nfs-storage"   #指定動態(tài)PV名稱 
  33.       accessModes: 
  34.       - ReadWriteOnce           #訪問模式,讀寫在單臺機器 
  35.       resources: 
  36.         requests: 
  37.           storage: 1Gi 
  38.  
  39.  
  40. root@k8s-master1:statefulset #  kubectl apply -f statefulset.yaml 
  41. statefulset.apps/web created 
  42.  
  43. root@k8s-master1:~/kubernetes/statefulset# kubectl get pv 
  44. NAME                                       CAPACITY   ACCESS MODES   RECLAIM POLICY   STATUS   CLAIM                     STORAGECLASS          REASON   AGE 
  45. pvc-8eacbe25-3875-4f78-91ca-ba83b6967a8a   100Gi      RWX            Delete           Bound    redis/nfs-redis           managed-nfs-storage            6d 
  46. pvc-935033b7-9ac8-4346-8543-1f95492dcde9   1Gi        RWO            Delete           Bound    default/nginx-pvc-web-1   managed-nfs-storage            39s 
  47. pvc-bd3a8c59-b66d-457b-a6f2-90f3b7f9ebf0   1Gi        RWO            Delete           Bound    default/nginx-pvc-web-2   managed-nfs-storage            19s 
  48. pvc-be5cf42a-aeaa-4667-901c-77e1d2350f49   1Gi        RWO            Delete           Bound    default/nginx-pvc-web-0   managed-nfs-storage            61s 
  49.  
  50.  
  51.  
  52. root@k8s-master1:~/kubernetes/statefulset# kubectl get pvc 
  53. NAME              STATUS   VOLUME                                     CAPACITY   ACCESS MODES   STORAGECLASS          AGE 
  54. nginx-pvc-web-0   Bound    pvc-be5cf42a-aeaa-4667-901c-77e1d2350f49   1Gi        RWO            managed-nfs-storage   82s 
  55. nginx-pvc-web-1   Bound    pvc-935033b7-9ac8-4346-8543-1f95492dcde9   1Gi        RWO            managed-nfs-storage   61s 
  56. nginx-pvc-web-2   Bound    pvc-bd3a8c59-b66d-457b-a6f2-90f3b7f9ebf0   1Gi        RWO            managed-nfs-storage   40s 
  57.  
  58. oot@k8s-master1:~/kubernetes/statefulset# kubectl get pods --show-labels  
  59. NAME                                      READY   STATUS    RESTARTS   AGE     LABELS 
  60. web-0                                     1/1     Running   0          4m50s   app=nginx,controller-revision-hash=web-b56c497b,statefulset.kubernetes.io/pod-name=web-0 
  61. web-1                                     1/1     Running   0          4m29s   app=nginx,controller-revision-hash=web-b56c497b,statefulset.kubernetes.io/pod-name=web-1 
  62. web-2                                     1/1     Running   0          4m8s    app=nginx,controller-revision-hash=web-b56c497b,statefulset.kubernetes.io/pod-name=web-2 
  63.  
  64. #分別進入到3個pod 中,寫入一個數(shù)據(jù),驗證各自的獨享存儲 
  65. root@k8s-master1:~/kubernetes/statefulset# kubectl  get pods -o wide --selector app=nginx 
  66. NAME                                READY   STATUS    RESTARTS   AGE     IP               NODE        NOMINATED NODE   READINESS GATES 
  67. web-0                               1/1     Running   0          7m6s    10.244.169.179   k8s-node2   <none>           <none> 
  68. web-1                               1/1     Running   0          6m45s   10.244.107.228   k8s-node3   <none>           <none> 
  69. web-2                               1/1     Running   0          6m24s   10.244.169.180   k8s-node2   <none>           <none> 
  70.  
  71.  
  72. [root@master-1 ~]# kubectl exec -it web-0 -- bash -c "echo 'congratulations  web-0 for k8s' > /usr/share/nginx/html/index.html" 
  73. [root@master-1 ~]# kubectl exec -it web-1 -- bash -c "echo 'congratulations  web-1 for k8s' > /usr/share/nginx/html/index.html" 
  74. [root@master-1 ~]# kubectl exec -it web-2 -- bash -c "echo 'congratulations  web-2 for k8s' > /usr/share/nginx/html/index.html" 
  75.  
  76.  
  77. #直接訪問pod IP 測試內(nèi)容: 
  78. root@k8s-master1:~/kubernetes/statefulset# curl 10.244.169.179 
  79. congratulations  web-0 for k8s 
  80.  
  81. root@k8s-master1:~/kubernetes/statefulset# curl  10.244.107.228 
  82. congratulations  web-1 for k8s 
  83.  
  84. root@k8s-master1:~/kubernetes/statefulset#  curl 10.244.169.180 
  85. congratulations  web-2 for k8s 

刪除statefulset

刪除statefulset 有兩張方法,級聯(lián)刪除 和 非級聯(lián)刪除

  • 使用非級聯(lián)刪除 statefulset 時,statefulset 的POD 不會被刪除
  • 使用級聯(lián)刪除時,statefulset 和 pod 都會被刪除
  1. (1)、非級聯(lián)刪除 
  2.  
  3. 使用kubectl  delete statefulset XXXX 刪除 statefulset ,只需要提供 --cascade=false 參數(shù),就會采用非聯(lián)機刪除,此時刪除statefulset 不會刪除pod 
  4.  
  5. kubectl delete statefulset web --cascade=false 
  6.  
  7.  
  8. (2)、級聯(lián)刪除 
  9. 省略 --cascade=false 參數(shù) 即可 
  10.  
  11. kubectl delete statefulset web  

 

責任編輯:姜華 來源: 今日頭條
相關(guān)推薦

2010-03-02 16:22:31

WCF狀態(tài)應用

2009-12-22 10:16:54

WCF服務狀態(tài)

2011-03-28 11:05:17

ODBC

2014-04-16 15:11:19

Spark

2012-09-11 14:39:03

Moosefs

2009-03-20 11:46:10

MGCP協(xié)議網(wǎng)關(guān)

2010-01-25 10:57:57

Android系統(tǒng)應用

2022-11-02 09:39:51

數(shù)據(jù)恢復Kubernetes

2018-02-02 16:32:10

KubernetesDocker命令

2010-06-24 13:26:53

FTP協(xié)議

2009-12-21 10:27:52

WCF基本概念

2009-12-29 18:29:09

Silverlight

2010-02-23 16:32:29

WCF服務

2017-04-07 10:19:22

交易支付概念

2010-08-23 16:58:17

DHCP協(xié)議

2011-07-19 13:44:39

JavaScript

2009-08-18 10:34:31

Java入門基本概念

2010-07-07 15:17:40

LDAP協(xié)議

2010-07-12 09:43:38

Symbian開發(fā)

2012-12-03 17:12:10

HDFS
點贊
收藏

51CTO技術(shù)棧公眾號