广告
返回顶部
首页 > 资讯 > 数据库 >K8s中MySQL 数据持久化存储的实现
  • 271
分享到

K8s中MySQL 数据持久化存储的实现

K8s MySQL数据持久化存储K8s MySQL数据持久化 2023-01-09 06:01:25 271人浏览 安东尼
摘要

目录一、步骤二、实践2.1 创建 PV 和 PVC2.2 部署 Mysql 服务2.3 创建测试数据2.4 模拟节点宕机2.5 数据一致性验证FAQ一、步骤 (1)创建 PV 和 PVC。 (2)部署 mysql 服务。

一、步骤

(1)创建 PV 和 PVC。

(2)部署 mysql 服务。

(3)向 Mysql 添加数据。

(4)模拟节点宕机,kubernetes 实现 MySQL 自动故障转移。

(5)自动故障转移后进行数据一致性验证。

:本次通过 NFS 做数据持久化存储。

二、实践

2.1 创建 PV 和 PVC

1、创建 PV

vim mysql-pv.yml

apiVersion: v1
kind: PersistentVolume
metadata:
  name: mysql-pv
  labels:
    pv: pv-test
spec:
  AcceSSModes:
    - ReadwriteOnce
  capacity:
    storage: 1Gi
  persistentVolumeReclaimPolicy: Retain
  storageClassName: nfs
  nfs:
    path: /home/data/app
    server: 192.168.56.160

2、创建 PVC

vim mysql-pvc.yml

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

3、创建 PV 和 PVC 资源

kubectl apply -f mysql-pv.yml
kubectl apply -f mysql-pvc.yml

查看 PV、PVC 资源

kubectl get pv,pvc

image-20230105100708675

2.2 部署 MySQL 服务

1、创建 YAML 文件

vim mysql.yml

apiVersion: v1
kind: Service
metadata:
  name: mysql
spec:
  selector:
    app: mysql
  ports:
    - protocol: tcp
      port: 3306
      targetPort: 3306
      nodePort: 31306
  type: NodePort
---
apiVersion: apps/v1
kind: Deployment
metadata:
  name: mysql
  labels:
    app: mysql-test
spec:
  replicas: 1
  selector:
    matchLabels:
      app: mysql
  template:
    metadata:
      labels:
        app: mysql
    spec:
      containers:
      - name: mysql-test
        image: mysql:5.7
        env:
        - name: MYSQL_ROOT_PASSWord
          value: Zhurs@123
        ports:
        - containerPort: 3306
        volumeMounts:
        - mountPath: "/var/lib/mysql"
          name: mysql-data
      volumes:
      - name: mysql-data
        persistentVolumeClaim:
          claimName: mysql-pvc

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

2、部署 MySQL 服务

kubectl apply -f mysql.yml

查看 Pod、Service 资源,看是否正常运行。

image-20230105105124485

2.3 创建测试数据

1、进入MySQL 数据库

kubectl exec -it mysql-574654d66c-hhvxc -- mysql -uroot -pZhurs@123

image-20230105105638454

2、创建测试数据

mysql> create database testdb;
mysql> use testdb;
mysql> create table t1(id int);
mysql> insert into t1 values(12);
mysql> select * from t1;

image-20230105110029135

2.4 模拟节点宕机

1、先看看 MySQL 服务运行在哪个节点上

kubectl get pod -o wide

image-20230105110508216

2、停掉 k8s-work1 节点

init 0

image-20230105110707873

image-20230105110912194

3、一段时间后 MySQL 迁移到 k8s-work2 节点上

原来的 Pod 停止服务,新的 Pod 正在创建,而且是在 k8s-work2 节点上进行创建。

image-20230105111322680

最终 MySQL 服务成功迁移至 k8s-work2 节点上,我原本的 Nginx 服务也成功迁移到了 k8s-work2 节点了。

image-20230105113349459

2.5 数据一致性验证

1、进入MySQL 数据库

kubectl exec -it mysql-574654d66c-jst7g -- mysql -uroot -pZhurs@123

image-20230105113543824

2、验证数据一致性

image-20230105113730556

可见,迁移后的 MySQL 数据依然是完整的。

FAQ

1、报错类型

注意一点,因为我们使用的是 NFS 文件共享存储,因此目标节点必须要有 NFS 的客户端服务,下图就是我没安装 NFS 客户端服务的原因。

image-20230105112755921

2、解决方案

在目标节点(k8s-work1)部署 NFS 服务

yum -y install rpcbind
yum -y install nfs-utils
systemctl start nfs-server
systemctl enable nfs-server
systemctl start rpcbind
systemctl enable rpcbind

最后在看看输出日志,Pod 正常运行了。

image-20230105112956370

到此这篇关于K8s中MySQL 数据持久化存储的实现的文章就介绍到这了,更多相关K8s MySQL数据持久化存储内容请搜索我们以前的文章或继续浏览下面的相关文章希望大家以后多多支持我们!

您可能感兴趣的文档:

--结束END--

本文标题: K8s中MySQL 数据持久化存储的实现

本文链接: https://www.lsjlt.com/news/177113.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • K8s中MySQL 数据持久化存储的实现
    目录一、步骤二、实践2.1 创建 PV 和 PVC2.2 部署 MySQL 服务2.3 创建测试数据2.4 模拟节点宕机2.5 数据一致性验证FAQ一、步骤 (1)创建 PV 和 P...
    99+
    2023-01-08
    K8s MySQL数据持久化存储 K8s MySQL数据持久化
  • K8s中MySQL 数据持久化存储的实现
    目录一、步骤二、实践2.1 创建 PV 和 PVC2.2 部署 mysql 服务2.3 创建测试数据2.4 模拟节点宕机2.5 数据一致性验证FAQ一、步骤 (1)创建 PV 和 PVC。 (2)部署 MySQL 服务。...
    99+
    2023-01-09
    K8s MySQL数据持久化存储 K8s MySQL数据持久化
  • mysql怎么实现数据持久化
    MySQL可以通过以下几种方式来实现数据持久化: 使用磁盘存储:MySQL将数据存储在硬盘上,包括数据文件、日志文件等。这样即使...
    99+
    2023-10-21
    mysql
  • Spring Data JPA怎么实现持久化存储数据到数据库
    这篇“Spring Data JPA怎么实现持久化存储数据到数据库”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看...
    99+
    2023-06-30
  • mysql表数据持久化怎么实现
    在MySQL中,数据持久化是通过将数据存储在磁盘上的表中来实现的。以下是一些实现数据持久化的方法: 创建表:首先需要创建一个表来...
    99+
    2023-10-26
    mysql
  • docker 挂载MySQL实现数据持久化的实现
    目录环境配置MySQL数据持久化注意事项环境配置 本地操作系统:Win10虚拟机的操作系统:CentOS Stream 8已安装docker,可以参考详细安装教程 MySQL数据持久...
    99+
    2022-11-13
  • Spring Data JPA实现持久化存储数据到数据库的示例代码
    目录1.SpringBoot项目整合JPA1.1 pom.xml依赖1.2 application配置文件2.创建实体类3.启动项目,测试验证1.SpringBoot项目整合JPA ...
    99+
    2022-11-13
  • kubernetes中部署mysql集群并持久化存储
    在Kubernetes中部署MySQL集群并持久化存储,可以使用StatefulSet和PersistentVolumeClaim(...
    99+
    2023-09-14
    mysql
  • docker持久化存储数据的方法是什么
    Docker提供了多种方法来实现持久化存储数据:1. 数据卷(Volumes):数据卷是一个特殊的目录,可以绕过容器文件系统来直接访...
    99+
    2023-10-27
    docker
  • Android持久化存储(3)SQLite数据库的使用
    1.什么是SQlite SQLite是由C语言编写的一款轻型数据库,因占用资源小,处理速度快,功能齐全,特别适用于移动设备,最重要的是开源,任何...
    99+
    2022-06-06
    存储 sqlite数据库 SQLite Android
  • Ruby序列化和持久化存储怎么实现
    这篇文章主要介绍“Ruby序列化和持久化存储怎么实现”,在日常操作中,相信很多人在Ruby序列化和持久化存储怎么实现问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Ruby序列化和持久化存储怎么实现”的疑惑有所...
    99+
    2023-06-30
  • Spring Data JPA数据持久化存储到数据库的方法
    今天小编给大家分享一下Spring Data JPA数据持久化存储到数据库的方法的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面...
    99+
    2023-06-30
  • Docker的持久化存储和数据共享是什么
    这篇“Docker的持久化存储和数据共享是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇...
    99+
    2022-10-19
  • mysql实现数据持久化的方式有哪些
    MySQL实现数据持久化的方式主要有以下几种: 数据库存储:MySQL是一种关系型数据库管理系统,最常见的方式是将数据存储在数据...
    99+
    2023-10-26
    mysql
  • 如何利用Kubernetes实现容器的持久化存储
    本篇内容主要讲解“如何利用Kubernetes实现容器的持久化存储”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何利用Kubernetes实现容器的持久化存储”吧!  可以说,容器化彻底改变了...
    99+
    2023-06-04
  • Python pickle模块实现Python对象持久化存储
    目录前言:pickle.dumps()函数pickle.loads()函数pickle.dump()函数pickle.load()函数总结:前言: Python 中有个序列化过程叫作...
    99+
    2022-11-11
  • js实现本地持久化存储登录注册
    本文实例为大家分享了js实现本地持久化存储登录注册的具体代码,供大家参考,具体内容如下 1.登录html文件 <!DOCTYPE html> <html lang...
    99+
    2022-11-13
  • redis数据持久化的实现方法
    小编给大家分享一下redis数据持久化的实现方法,希望大家阅读完这篇文章后大所收获,下面让我们一起去探讨吧!Redis实现数据持久化的两种实现方式:RDB:指定的时间间隔内保存数据快照AOF:先把命令追加到...
    99+
    2022-10-18
  • mongodb数据持久化怎么实现
    在MongoDB中,数据持久化是通过将数据写入硬盘来实现的。MongoDB会在后台自动将数据写入到磁盘中,以确保数据的持久性。 Mo...
    99+
    2023-10-21
    mongodb
  • android数据持久化怎么实现
    在Android中,有多种方式可以实现数据持久化,下面列举了几种常见的方法:1. Shared Preferences(共享首选项)...
    99+
    2023-10-21
    android
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作