Postgres, работающий на kubernetes, теряет данные при восстановлении Pod или перезагрузке кластера - PullRequest
0 голосов
/ 23 сентября 2019

У меня есть контейнер postgres , работающий в Pod на GKE и PersistentVolume, настроенном для хранения данных.Однако все данные в базе данных будут потеряны при перезагрузке кластера или при удалении Pod.

Если я запускаю kubectl delete <postgres_pod> для удаления существующего Pod и проверяю вновь созданного ( kubernetes ) Pod для замены удаленного, соответствующая база данных не имеет данныхчто было до удаления Pod.

Вот файлы yaml , которые я использовал для развертывания postgres .

apiVersion: storage.k8s.io/v1
kind: StorageClass
metadata:
  name: custom-storage
parameters:
  type: pd-standard
provisioner: kubernetes.io/gce-pd
reclaimPolicy: Retain
volumeBindingMode: Immediate
---
kind: PersistentVolumeClaim
apiVersion: v1
metadata:
  name: postgres-volume-claim
spec:
  storageClassName: custom-storage
  accessModes:
    - ReadWriteOnce
  resources:
    requests:
      storage: 5Gi

deploy.yaml

apiVersion: apps/v1
kind: Deployment
metadata:
  name: postgres
spec:
  selector:
    matchLabels:
      app: postgres
  template:
    metadata:
      labels:
        app: postgres
    spec:
      containers:
      - name: postgres
        image: postgres:11.5
        resources: {}
        ports:
        - containerPort: 5432
        env:
          - name: POSTGRES_DB
            value: "dbname"
          - name: POSTGRES_USER
            value: "user"
          - name: POSTGRES_PASSWORD
            value: "password"
        volumeMounts:
          - mountPath: /var/lib/postgresql/
            name: postgresdb
      volumes:
        - name: postgresdb
          persistentVolumeClaim:
            claimName: postgres-volume-claim

Я дважды проверил, что persistentVolumeReclaimPolicy имеет значение Retain.

Чего мне не хватает?

1 Ответ

1 голос
/ 24 сентября 2019

Создает ли кластер новый том каждый раз, когда вы удаляете модуль?Проверьте с kubectl get pv.

Это многозонный кластер?Ваш класс хранения не обеспечивает региональные диски, поэтому вы можете получить новый диск при перемещении модуля из одной зоны в другую.

Возможно, из-за вашей проблемы, ссылка на контейнер postgres рекомендует монтировать на /var/lib/postgresql/data/pgdata иустановка переменной PGDATA env: https://hub.docker.com/_/postgres#pgdata

...