本节演示如何为 MySQL 数据库提供持久化存储,步骤为:

  1. 创建 PV 和 PVC。

  2. 部署 MySQL。

  3. 向 MySQL 添加数据。

  4. 模拟节点宕机故障,Kubernetes 将 MySQL 自动迁移到其他节点。

  5. 验证数据一致性。

首先创建 PV 和 PVC,配置如下:

mysql-pv.yml

MySQL 如何使用 PV 和 PVC?- 每天5分钟玩转 Docker 容器技术(154)_Docker

mysql-pvc.yml

MySQL 如何使用 PV 和 PVC?- 每天5分钟玩转 Docker 容器技术(154)_Kubernetes_02

创建 mysql-pv 和 mysql-pvc

MySQL 如何使用 PV 和 PVC?- 每天5分钟玩转 Docker 容器技术(154)_Docker_03

接下来部署 MySQL,配置文件如下:

MySQL 如何使用 PV 和 PVC?- 每天5分钟玩转 Docker 容器技术(154)_Kubernetes_04

PVC mysql-pvc Bound 的 PV mysql-pv 将被 mount 到 MySQL 的数据目录 var/lib/mysql

MySQL 如何使用 PV 和 PVC?- 每天5分钟玩转 Docker 容器技术(154)_Docker_05

MySQL 被部署到 k8s-node2,下面通过客户端访问 Service mysql

kubectl run -it --rm --image=mysql:5.6 --restart=Never mysql-client -- mysql -h mysql -ppassword


MySQL 如何使用 PV 和 PVC?- 每天5分钟玩转 Docker 容器技术(154)_Kubernetes_06

更新数据库:

MySQL 如何使用 PV 和 PVC?- 每天5分钟玩转 Docker 容器技术(154)_容器_07

① 切换到数据库 mysql。

② 创建数据库表 my_id。

③ 插入一条数据。

④ 确认数据已经写入。

关闭 k8s-node2,模拟节点宕机故障。

MySQL 如何使用 PV 和 PVC?- 每天5分钟玩转 Docker 容器技术(154)_Kubernetes_08

一段时间后,Kubernetes 将 MySQL 迁移到 k8s-node1

MySQL 如何使用 PV 和 PVC?- 每天5分钟玩转 Docker 容器技术(154)_教程_09

验证数据的一致性:

MySQL 如何使用 PV 和 PVC?- 每天5分钟玩转 Docker 容器技术(154)_教程_10

MySQL 服务恢复,数据也完好无损。

小结

本章我们讨论了 Kubernetes 如何管理存储资源。

emptyDir 和 hostPath 类型的 Volume 很方便,但可持久性不强,Kubernetes 支持多种外部存储系统的 Volume。

PV 和 PVC 分离了管理员和普通用户的职责,更适合生产环境。我们还学习了如何通过 StorageClass 实现更高效的动态供给。

最后,我们演示了如何在 MySQL 中使用 PersistentVolume 实现数据持久性。

书籍:

1.《每天5分钟玩转Kubernetes》
https://item.jd.com/26225745440.html

2.《每天5分钟玩转Docker容器技术》
https://item.jd.com/16936307278.html

3.《每天5分钟玩转OpenStack》
https://item.jd.com/12086376.html

MySQL 如何使用 PV 和 PVC?- 每天5分钟玩转 Docker 容器技术(154)_Kubernetes_11