k8s练习--通过NFS+PV+PVC+POD,部署一个MySQL服务,并将MySQL的数据进行持久化存储

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
容器服务 Serverless 版 ACK Serverless,952元额度 多规格
简介: 本文档介绍了如何使用Kubernetes (K8s)、NFS、PersistentVolume (PV)、PersistentVolumeClaim (PVC)和Pod来部署并实现MySQL服务的数据持久化存储。Kubernetes是一个用于自动化部署、扩展和管理容器化应用的强大平台。NFS作为一种网络文件系统协议,能够使Kubernetes集群中的Pod跨节点访问共享文件。PV和PVC机制则提供了持久化的存储解决方案,确保数据即使在Pod生命周期结束后仍得以保留。

前言

Kubernetes(常简称为 K8s):
是一个开源的容器编排平台,用于自动化部署、扩展和管理容器化应用程序。它提供了一个强大的工具集,可以简化容器化应用程序的部署、维护和扩展,从而使开发人员和运维团队更加轻松地管理复杂的容器化工作负载。

NFS (Network File System):
NFS 是一种网络文件系统协议,允许远程计算机通过网络访问共享文件。在 Kubernetes 中,可以将 NFS 服务器挂载到集群中的多个 Pod 上,以提供持久化存储。

PV (PersistentVolume):
PV 是 Kubernetes 中的一种资源,它表示一块持久化存储的卷。PV 独立于 Pod 存在,可以被多个 Pod 使用。管理员需要先创建 PV,然后才能被 Pod 使用。

PVC (PersistentVolumeClaim):
PVC 是对 PV 的请求,用于向 Kubernetes 集群请求持久化存储资源。Pod 通过 PVC 来申请 PV,并且只有在 PVC 和 PV 匹配成功时,Pod 才能成功绑定 PV。

Pod:
Pod 是 Kubernetes 中最小的部署单元,可以包含一个或多个容器。Pod 可以使用 PVC 来请求持久化存储,并且可以将 NFS 挂载到其中的容器中,以便存储和访问数据。

MySQL:
MySQL 是一个流行的开源关系型数据库管理系统,可以在容器中运行。通过将 MySQL Pod 与 PVC 绑定,可以实现 MySQL 数据的持久化存储,即使 Pod 被删除或重启,数据仍然可以被保留。

一、实验环境

三台主机均centos7.9
Ip | 主机名 | cpu | 内存 | 硬盘
----- | ----- | --- | --- | ---
192.168.10.11 | master | 1cpu双核 | 2G | 40G
192.168.10.12 | node01 | 1cpu双核 | 2G | 40G
192.168.10.13 | node02 | 1cpu双核 | 2G | 40g

k8s集群已配置
版本 1.18.0
nfs配置在master上

结尾有所有yaml文件的详细解释

二、具体步骤

1.准备存储设备:这里使用的是NFS

所有节点都安装nfs-utils工具包和rpc-bind服务。

yum -y install nfs-utils rpcbind -y

这里准备将NFS服务部署在master节点上,需要在master节点上提前规划好共享的目录

[root@master ~]#  vim /etc/exports 
输入 /nfsdata *(rw,sync,no_root_squash) 
:wq 保存退出

[root@master ~]#  systemctl start rpcbind 
[root@master ~]#  systemctl enable rpcbind 
[root@master ~]#  systemctl start nfs-server 
[root@master ~]#  systemctl enable nfs-server 
[root@master ~]#  showmount -e

nfs成功部署
在这里插入图片描述

2.现在部署一个MySQL服务,并且将MySQL的数据进行持久化存储。

(1)创建PV,PVC

编写pv的yaml文件
[root@master ~]# vim mysql-pv.yaml

kind: PersistentVolume 
apiVersion: v1 
metadata: 
  name: mysql-pv 
spec: 
  accessModes: 
    - ReadWriteOnce 
  capacity: 
    storage: 1Gi 
  persistentVolumeReclaimPolicy: Retain 
  storageClassName: nfs 
  nfs:
    path: /nfsdata/mysql-pv 
    server: 192.168.10.11

编写pvc的yaml文件
[root@master ~]# vim mysql-pvc.yaml

kind: PersistentVolumeClaim 
apiVersion: v1 
metadata: 
  name: mysql-pvc 
spec: 
  accessModes: 
    - ReadWriteOnce
  storageClassName: nfs 
  resources: 
    requests: 
      storage: 1Gi

[root@master ~]# mkdir /nfsdata/mysql-pv
[root@master ~]# kubectl apply -f mysql-pv.yaml
创建pv

[root@master ~]# kubectl apply -f mysql-pvc.yaml
创建pvc

[root@master ~]# kubectl get pv,pvc
获得pv和pvc的信息
在这里插入图片描述

(2)部署MySQL

编写关于mysql的deployment与service的yaml文件
[root@master ~]# vim mysql.yaml

kind: Deployment
apiVersion: apps/v1
metadata:
  name: mysql
spec:
  selector:
    matchLabels:
      app: mysql
  template:
    metadata:
      labels:
        app: mysql
    spec:
      containers:
      - name: mysql
        image: mysql:5.7
        imagePullPolicy: IfNotPresent
        env:
        - name: MYSQL_ROOT_PASSWORD
          value: 123.com
        volumeMounts:
        - name: mysql-storage
          mountPath: /var/lib/mysql
      volumes:
      - name: mysql-storage
        persistentVolumeClaim:
          claimName: mysql-pvc 

--- 
kind: Service 
apiVersion: v1 
metadata: 
  name: mysql 
spec: 
  type: NodePort
  selector: 
    app: mysql 
  ports: 
    - port: 3306 
      targetPort: 3306 
      nodePort: 31306

(3)在MySQL数据库中添加数据

获得pod的资源信息
[root@master ~]# kubectl get pod
在这里插入图片描述
根据获得的name登录mysql
[root@master ~]# kubectl exec -it mysql-5d86c64fc9-2294l -- mysql -uroot -p123.com

mysql> SHOW DATABASES;                     //查看当前的库。
mysql> CREATE DATABASE auth;                 //创建auth库。
mysql> USE auth;                             //选择使用auth库。 
mysql> CREATE TABLE users(user_name char(10),user_passwd char(40));         //创建my_id表
mysql> INSERT users values ('zhangsan','123');                     //往my_id表中,插入数据。
mysql> SELECT * FROM users;                                 //查看my_id表中所有数据

在这里插入图片描述

(4)模拟MySQ服务器节点故障

获取 Kubernetes 集群中所有 Pod 的信息,并显示更多的详细信息
[root@master ~]# kubectl get pod -o wide

在这里插入图片描述
删除pod,k8s集群会产生一个新的Pod,验证这个Pod内是否有之前数据。

[root@master ~]# kubectl delete pod mysql-5d86c64fc9-2294l 
[root@master ~]# kubectl get pod -o wide

在这里插入图片描述
根据新pod名称登录mysql查看

[root@master ~]# kubectl exec -it mysql-5d86c64fc9-vqkh7 -- mysql -u root -p123.com
mysql> show databases; 
mysql> use auth; 
mysql> show tables; 
mysql> select * from users;

可以发现数据依然存在
在这里插入图片描述

查看nfs
[root@master ~]# ls /nfsdata/mysql-pv/
在这里插入图片描述
有数据
实验完成

总结

三个yaml文件的详细解释

pv

kind: PersistentVolume:这一行指定了资源对象的类型为持久卷。
apiVersion: v1:指定了Kubernetes API的版本。
metadata: name: mysql-pv:在元数据部分定义了持久卷的名称为mysql-pv。
spec: :这个部分包含了持久卷的规格说明。
accessModes: - ReadWriteOnce:指定了持久卷的访问模式,这里是ReadWriteOnce,表示可以被单个节点挂载为读写模式访问。
capacity: storage: 1Gi:定义了持久卷的存储容量为1GB。
persistentVolumeReclaimPolicy: Retain:指定了当持久卷上的所有声明被删除后,保留持久卷的数据,需要手动处理。
storageClassName: nfs:指定了存储类型的类名为nfs,这将与存储类(StorageClass)相关联,用于动态分配持久卷。
nfs: path: /nfsdata/mysql-pv:这里指定了NFS存储的路径为/nfsdata/mysql-pv。
server: 192.168.10.11:指定了NFS服务器的地址为192.168.10.11,这是提供NFS存储的服务器地址。

pvc

kind: PersistentVolumeClaim:这一行指定了资源对象的类型为持久卷声明。
apiVersion: v1:指定了Kubernetes API的版本。
metadata: name: mysql-pvc:在元数据部分定义了持久卷声明的名称为mysql-pvc。
spec: :这个部分包含了持久卷声明的规格说明。
accessModes: - ReadWriteOnce:指定了持久卷声明的访问模式,这里是ReadWriteOnce,表示需要一个节点挂载为读写模式访问。
storageClassName: nfs:指定了存储类型的类名为nfs,这将与存储类(StorageClass)相关联,用于动态分配持久卷。
resources: requests: storage: 1Gi:定义了持久卷声明需要的存储资源,这里请求了1GB的存储容量。

mysql

Deployment部分:

kind: Deployment:指定了资源对象的类型为部署。
apiVersion: apps/v1:指定了Kubernetes API的版本。
metadata: name: mysql:在元数据部分定义了部署的名称为mysql。
spec: :这个部分包含了部署的规格说明。
selector: matchLabels: app: mysql:指定了用于选择Pod的标签。
template: metadata: labels: app: mysql:定义了Pod的模板,设置了Pod的标签。
spec: containers: - name: mysql:指定了容器的名称为mysql。
image: mysql:5.7:使用的MySQL镜像的版本。
imagePullPolicy: IfNotPresent:设置容器拉取镜像的策略为如果本地不存在才拉取。
env: - name: MYSQL_ROOT_PASSWORD value: 123.com:设置了MySQL根密码的环境变量。
volumeMounts: - name: mysql-storage mountPath: /var/lib/mysql:指定了挂载持久卷的路径。
volumes: - name: mysql-storage persistentVolumeClaim: claimName: mysql-pvc:定义了用于挂载的持久卷声明名称。

Service部分:
kind: Service:指定了资源对象的类型为服务。
apiVersion: v1:指定了Kubernetes API的版本。
metadata: name: mysql:在元数据部分定义了服务的名称为mysql。
spec: type: NodePort:定义了服务的类型为NodePort。
selector: app: mysql:指定了用于选择后端Pod的标签。
ports: - port: 3306 targetPort: 3306 nodePort: 31306:定义了服务暴露的端口以及节点端口。

以上就是今天学习的内容,通过NFS+PV+PVC+POD,部署一个MySQL服务,并将MySQL的数据进行持久化存储,希望对各位有所帮助
若有错误,请指出,见立改

相关实践学习
通过Ingress进行灰度发布
本场景您将运行一个简单的应用,部署一个新的应用用于新的发布,并通过Ingress能力实现灰度发布。
容器应用与集群管理
欢迎来到《容器应用与集群管理》课程,本课程是“云原生容器Clouder认证“系列中的第二阶段。课程将向您介绍与容器集群相关的概念和技术,这些概念和技术可以帮助您了解阿里云容器服务ACK/ACK Serverless的使用。同时,本课程也会向您介绍可以采取的工具、方法和可操作步骤,以帮助您了解如何基于容器服务ACK Serverless构建和管理企业级应用。 学习完本课程后,您将能够: 掌握容器集群、容器编排的基本概念 掌握Kubernetes的基础概念及核心思想 掌握阿里云容器服务ACK/ACK Serverless概念及使用方法 基于容器服务ACK Serverless搭建和管理企业级网站应用
相关文章
|
25天前
|
安全 关系型数据库 MySQL
如何将数据从MySQL同步到其他系统
【10月更文挑战第17天】如何将数据从MySQL同步到其他系统
140 0
|
7天前
|
存储 Oracle 关系型数据库
【赵渝强老师】MySQL InnoDB的数据文件与重做日志文件
本文介绍了MySQL InnoDB存储引擎中的数据文件和重做日志文件。数据文件包括`.ibd`和`ibdata`文件,用于存放InnoDB数据和索引。重做日志文件(redo log)确保数据的可靠性和事务的持久性,其大小和路径可由相关参数配置。文章还提供了视频讲解和示例代码。
112 11
【赵渝强老师】MySQL InnoDB的数据文件与重做日志文件
|
7天前
|
缓存 NoSQL 关系型数据库
Redis和Mysql如何保证数据⼀致?
在项目中,为了解决Redis与Mysql的数据一致性问题,我们采用了多种策略:对于低一致性要求的数据,不做特别处理;时效性数据通过设置缓存过期时间来减少不一致风险;高一致性但时效性要求不高的数据,利用MQ异步同步确保最终一致性;而对一致性和时效性都有高要求的数据,则采用分布式事务(如Seata TCC模式)来保障。
39 14
|
9天前
|
SQL 前端开发 关系型数据库
SpringBoot使用mysql查询昨天、今天、过去一周、过去半年、过去一年数据
SpringBoot使用mysql查询昨天、今天、过去一周、过去半年、过去一年数据
39 9
|
21天前
|
SQL Java 关系型数据库
java连接mysql查询数据(基础版,无框架)
【10月更文挑战第12天】该示例展示了如何使用Java通过JDBC连接MySQL数据库并查询数据。首先在项目中引入`mysql-connector-java`依赖,然后通过`JdbcUtil`类中的`main`方法实现数据库连接、执行SQL查询及结果处理,最后关闭相关资源。
|
18天前
|
SQL 关系型数据库 MySQL
定时任务频繁插入数据导致锁表问题 -> 查询mysql进程
定时任务频繁插入数据导致锁表问题 -> 查询mysql进程
37 1
|
19天前
|
SQL 关系型数据库 MySQL
mysql数据误删后的数据回滚
【11月更文挑战第1天】本文介绍了四种恢复误删数据的方法:1. 使用事务回滚,通过 `pymysql` 库在 Python 中实现;2. 使用备份恢复,通过 `mysqldump` 命令备份和恢复数据;3. 使用二进制日志恢复,通过 `mysqlbinlog` 工具恢复特定位置的事件;4. 使用延迟复制从副本恢复,通过停止和重启从库复制来恢复数据。每种方法都有详细的步骤和示例代码。
|
6月前
|
Linux
Linux安装NFS挂载NFS卸载客户端服务端都有
Linux安装NFS挂载NFS卸载客户端服务端都有
153 0
|
6月前
|
Ubuntu 网络协议 Unix
【Linux】新唐NUC977挂载NFS实现网络文件传输
【Linux】新唐NUC977挂载NFS实现网络文件传输
|
6月前
|
Linux Shell Windows
通过Linux挂载Windows端NFS服务实现板端Linux传输文件到PC
通过Linux挂载Windows端NFS服务实现板端Linux传输文件到PC
419 0

推荐镜像

更多