簡體   English   中英

Kubernetes StatefulSet - 在 pod 重啟時不恢復數據

[英]Kubernetes StatefulSet - does not resatore data on pod restart

Kubernetes 版本 - 1.8

  1. 使用 pvc 為 postgres 數據庫創建 statefulset
  2. 向數據庫添加了一些表
  3. 通過將 statefulset 縮放到 0 然后再縮放到 1 來重新啟動 pod
  4. 第 2 步中創建的表不再可用

在 docker-for-desktop 集群 k8s 版本 1.10 上嘗試了另一個 snario

  1. 使用 pvc 為 postgres 數據庫創建 statefulset
  2. 向數據庫添加了一些表
  3. 重新啟動桌面 docker
  4. 第 2 步中創建的表不再可用

k8s清單

    apiVersion: v1
kind: ConfigMap
metadata:
  name: postgres-config
  labels:
    app: postgres
data:
  POSTGRES_DB: kong
  POSTGRES_USER: kong
  POSTGRES_PASSWORD: kong
  PGDATA: /var/lib/postgresql/data/pgdata
---
apiVersion: v1
kind: PersistentVolume
metadata:
  name: postgres-pv
  labels:
    app: postgres
spec:
  storageClassName: manual
  capacity:
    storage: 1Gi
  accessModes:
    - ReadWriteOnce
  hostPath:
    path: "/mnt/postgresql/data"
---
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
  name: postgres-pvc
  labels:
    app: postgres
spec:
  storageClassName: manual
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 1Gi
---
apiVersion: v1
kind: Service
metadata:
  name: postgres
  app: postgres
spec:
  ports:
  - name: pgql
    port: 5432
    targetPort: 5432
    protocol: TCP
  selector:
    app: postgres
---
apiVersion: apps/v1beta2 #  for k8s versions before 1.9.0 use apps/v1beta2  and before 1.8.0 use extensions/v1beta1
kind: StatefulSet
metadata:
  name: postgres
spec:
  serviceName: "postgres"
  replicas: 1
  selector:
    matchLabels:
      app: postgres
  template:
    metadata:
      labels:
        app: postgres
    spec:
      containers:
        - name: postgres
          image: postgres:9.6
          imagePullPolicy: "IfNotPresent"
          ports:
            - containerPort: 5432
          envFrom:
            - configMapRef:
                name: postgres-config
          volumeMounts:
            - mountPath: /var/lib/postgresql/data
              name: postgredb
      volumes:
        - name: postgredb
          persistentVolumeClaim:
            claimName: postgres-pvc
---

如果您有多個節點 - 您看到的問題完全在意料之中。 因此,如果您想在多節點集群中使用 hostPath 作為持久卷 - 您必須使用一些共享文件系統,如 Glusterfs 或 Ceph,並將您的 /mnt/postgresql/data 文件夾放在該共享文件系統上。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM