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

本文涉及的产品
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
云数据库 RDS MySQL,高可用系列 2核4GB
简介: 本文档介绍了如何使用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搭建和管理企业级网站应用
相关文章
|
18天前
|
JSON Kubernetes Shell
【Azure K8S | AKS】在不丢失文件/不影响POD运行的情况下增加PVC的大小
【Azure K8S | AKS】在不丢失文件/不影响POD运行的情况下增加PVC的大小
|
18天前
|
Kubernetes Shell Perl
【Azure K8S|AKS】进入AKS的POD中查看文件,例如PVC Volume Mounts使用情况
【Azure K8S|AKS】进入AKS的POD中查看文件,例如PVC Volume Mounts使用情况
|
18天前
|
运维 Kubernetes 容器
【Azure K8S】演示修复因AKS密钥过期而导致创建服务不成功的问题(The provided client secret keys for app ****** are expired)
【Azure K8S】演示修复因AKS密钥过期而导致创建服务不成功的问题(The provided client secret keys for app ****** are expired)
【Azure K8S】演示修复因AKS密钥过期而导致创建服务不成功的问题(The provided client secret keys for app ****** are expired)
|
14天前
|
存储 Kubernetes 容器
k8s创建NFS动态存储
k8s创建NFS动态存储
|
19天前
|
Kubernetes Docker Perl
在K8S中,如果是因为开发写的镜像问题导致pod起不来该怎么排查?
在K8S中,如果是因为开发写的镜像问题导致pod起不来该怎么排查?
|
19天前
|
Kubernetes 安全 Docker
在K8S中,在服务上线的时候Pod起不来怎么进行排查?
在K8S中,在服务上线的时候Pod起不来怎么进行排查?
|
19天前
|
存储 Kubernetes 调度
在K8S中,⼀个pod的不同container能够分开被调动到不同的节点上吗?
在K8S中,⼀个pod的不同container能够分开被调动到不同的节点上吗?
|
15天前
|
存储 运维 Kubernetes
k8s学习笔记之StorageClass+NFS
k8s学习笔记之StorageClass+NFS
|
21天前
|
SQL 关系型数据库 MySQL
【揭秘】MySQL binlog日志与GTID:如何让数据库备份恢复变得轻松简单?
【8月更文挑战第22天】MySQL的binlog日志记录数据变更,用于恢复、复制和点恢复;GTID为每笔事务分配唯一ID,简化复制和恢复流程。开启binlog和GTID后,可通过`mysqldump`进行逻辑备份,包含binlog位置信息,或用`xtrabackup`做物理备份。恢复时,使用`mysql`命令执行备份文件,或通过`innobackupex`恢复物理备份。GTID模式下的主从复制配置更简便。
91 2
|
16天前
|
弹性计算 关系型数据库 数据库
手把手带你从自建 MySQL 迁移到云数据库,一步就能脱胎换骨
阿里云瑶池数据库来开课啦!自建数据库迁移至云数据库 RDS原来只要一步操作就能搞定!点击阅读原文完成实验就可获得一本日历哦~

推荐镜像

更多