记应用使用pvc后重启数据丢失问题

问题概述

使用官方 postgresql 镜像,容器数据使用pvc申请pv进行持久化,但在重启pod后数据库数据丢失。

配置文件

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
apiVersion: v1
kind: PersistentVolumeClaim
metadata:
name: pg-test
spec:
accessModes:
- ReadWriteOnce
resources:
requests:
storage: 1Gi
storageClassName: cephfs

---
apiVersion: apps/v1
kind: Deployment
metadata:
name: postgresql-deployment
spec:
selector:
matchLabels:
app: postgresql
template:
metadata:
labels:
app: postgresql
spec:
containers:
- image: postgres:12.4
name: postgresql
env:
- name: POSTGRES_PASSWORD
value: "123456"
ports:
- containerPort: 5432
name: postgresql
volumeMounts:
- name: postgresql-persistent-storage
## 注意挂载点
mountPath: /var/lib/postgresql
volumes:
- name: postgresql-persistent-storage
persistentVolumeClaim:
claimName: pg-test

验证重启数据丢失

  • 容器挂载目录下写入数据

  • 重启重启

  • 登录容器查看文件

    1
    进入容器发现上述创建的文件已不存在

问题分析

  • pod内查看挂载情况
    1
    2
    进入pod内,使用findmnt查看挂载发现数据库存储路径未在pv上,而是/dev/vda1磁盘挂载在/var/lib/postgresql/data目录。
    这也就解释重启pod后该目录数据会被释放,导致数据丢失。

  • 查看pg镜像构建
    1
    2
    docker history --no-trunc postgres:12.4
    # 可以看出镜像的dockerfile中使用VOLUME挂载了/var/lib/postgresql/data

修改deployment中挂载路径

1
2
3
改mountPath为/var/lib/postgresql/data后,重启测试数据还在

# 分析得出,如果dockerfile中有挂载路径,那k8s的工作负载不会覆盖掉kubelet拉起容器中的volume。
-------------本文结束感谢您的阅读-------------
原创技术分享,感谢您的支持。