我有 postgres 容器在 Pod
中运行在 GKE 和 PersistentVolume
上设置存储数据。但是,如果集群重新启动或 Pod
出现,数据库中的所有数据都会丢失。被删除。
如果我运行 kubectl delete <postgres_pod>
删除现有的 Pod
并检查新创建的(由 kubernetes)Pod
要替换已删除的数据库,相应的数据库没有 Pod
之前的数据被删除。
这是我用来部署 postgres 的 yaml 文件。
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
部署.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
具有值(value) Retain
.
我错过了什么?
最佳答案
集群是否在您每次删除 pod 时创建一个新卷?使用 kubectl get pv
检查。
这是一个多区域集群吗?您的存储类不是配置区域磁盘,因此当 pod 从一个区域移动到另一个区域时,您可能会获得一个新磁盘。
可能与您的问题有关,postgres 容器引用建议安装在 /var/lib/postgresql/data/pgdata
并设置 PGDATA
env 变量:
https://hub.docker.com/_/postgres#pgdata
关于docker - 在 kubernetes 上运行的 Postgres 在 Pod 重建或集群重启时丢失数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58069267/