1. 程式人生 > 其它 >十三、有狀態應用部署

十三、有狀態應用部署

技術標籤:k8s技術問題經驗linuxkubernetesdocker大資料

1.概念

有狀態:db  如果mysql的主從,必須是遠端的儲存,在任意節點都可以掛載恢復之前的狀態
網路ID唯一,從而知道主的地址,pod是短暫的,新的就會換IP,得保證這個IP能一直在使用
無狀態:web 比如部署2個副本,跟其他沒啥直接的關係,本地也沒有需要持久化的資料
其中有一個副本掛了,其他節點起來仍然可以提供服務沒有影響

K8S適合訪問波動大、版本迭代快的、彈性伸縮的

2.Headless Service

確保解析的名稱直達pod,給pod配置唯一名稱

3.StatefulSet(簡稱sts)

https://kubernetes.io/docs/concepts/workloads/controllers/statefulset/

StatefulSet與Deployment區別:有身份的! 
身份三要素: 
• 域名 
• 主機名 
• 儲存(PVC) 
ClusterIP A記錄格式: 
<service-name>.<namespace-name>.svc.cluster.local 
ClusterIP=None A記錄格式: 
<statefulsetName-index>.<service-name> .<namespace-name>.svc.cluster.local 
示例:web-0.nginx.default.svc.cluster.local 

• 部署有狀態應用 
• 解決Pod獨立生命週期,保持Pod啟動順序和唯一性 
1. 穩定,唯一的網路識別符號,持久儲存 
2. 有序,優雅的部署和擴充套件、刪除和終止 
3. 有序,滾動更新 
三個元件:headless service、StatefulSet、volumeClaimTemplate(卷申請模板) 

應用場景:資料庫
在這裡插入圖片描述
一個pod一個儲存卷,資料名字相同,但是資料不一樣

apiVersion: v1
kind: Service
metadata:
  name: nginx
  labels:
    app: nginx
spec:
  ports:
  - port: 80
    name: web
  clusterIP: None
  selector:
    app: nginx
---
apiVersion: apps/v1
kind: StatefulSet
metadata:
  name: web
spec:
  selector:
    matchLabels:
      app: nginx        #通過標籤選擇器關聯無頭service和pod
  serviceName: "nginx"    #選擇無頭service的名字
  replicas: 3           
  template:
    metadata:
      labels:
        app: nginx      # 跟標籤選擇器中的相同
    spec:
      terminationGracePeriodSeconds: 10
      containers:
      - name: nginx
        image: nginx
        ports:
        - containerPort: 80
          name: web
        volumeMounts:
        - name: www
          mountPath: /usr/share/nginx/html
  volumeClaimTemplates:
  - metadata:
      name: www
    spec:
      accessModes: [ "ReadWriteOnce" ]
      storageClassName: "managed-nfs-storage"         #指定儲存類自動pv供給           
      resources:
        requests:
          storage: 1Gi

4.注意:

(1)如果沒有自動供給,那麼需要定義儲存類來相關聯pv,因為自動建立pvc,需要關聯
需要解析的話  pod名字.無頭service名字.名稱空間
(2)可以直接進去其他pod nslookuo 無頭service會給出不同pod的名稱,可以通過名稱直接通訊
(3)因為是有序的,所以擴就是0-1-2-3,縮就是3-2-1-0

5更新策略

1.使用kubectl  set 直接更新
2.定義更新策略
金絲雀釋出
kubectl edit  statefulsets.apps  web 
  updateStrategy:
    rollingUpdate:
      partition: 4              #這裡的數字表示你pod的最後的字尾,如果>=的就更新
    type: RollingUpdate

在這裡插入圖片描述

這裡更換映象以後表示只有4更新0 1 2 3 保持不變
也可以用打補丁的方式修改,不過我這裡不太會只會edit
Kubectl   patch打補丁
回滾同理
kubectl rollout undo statefulset web  也是數字控制