У меня есть контейнер 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
.
Чего мне не хватает?