作者:程润科、钱芬

视频:钱芬

上一篇文章我们演示了如何快速实现 MySQL 高可用集群部署,以及部署集群的校验和卸载方式。本文将演示如何对集群进行备份和恢复。

部署版本为 RadonDB MySQL Kubernetes 2.1.3。

环境准备

首先准备一套 Kubernetes 集群,过程略。然后创建一套 RadonDB MySQL 集群。

步骤 1:下载源码

$ git clone https://github.com/radondb/radondb-mysql-kubernetes.git

步骤 2:安装 Operator

以下指定 release 名为 test , 创建一个名为 test-mysql-operator 的 Deployment。。

$ helm install test charts/mysql-operator

步骤 3:配置备份信息

Kubernetes Secret 资源信息需提前准备。文章及操作视频中的资源环境为青云云平台的 qingstor 对象存储。其他平台的密钥及 S3 存储服务创建过程类似,请另行参考。

创建 API 密钥

登录青云云平台官网,点击 产品与服务 -> API 密钥;进入入 API 密钥页面,点击 创建 API 密钥,输入名称后下载 s3-access-keys3-secret-key 明文信息。

创建 s3-bucket

点击 产品与服务 -> 对象存储;进入对象存储页面,点击 创建 Bucket,输入 bucket 名称后即可获得 bucket 明文信息:

  • s3-endpoint: http://s3.sh1a.qingstor.com
  • s3-access-key:VNXYHYHQUXZKUVZFGFRY
  • s3-secret-key:0zw7JKkbAAdlQKHPjTHWtoFGGQRvnQ5SJRc5P69r
  • s3-bucket: radondb-mysql-bucket s3-xxxx 的值是使用 base64 算法加密的,你可以这样获得。(此处对s3-xxx信息进行脱敏处理)。
$ echo -n "http://s3.sh1a.qingstor.com"|base64

创建 Kubernetes Secret 资源

创建backup_secret.yaml文件用来存放 S3 对象存储相关信息。(此处对s3-xxx信息进行脱敏处理)。

kind: Secret
apiVersion: v1
metadata:
name: sample-backup-secret
namespace: default
data:
s3-endpoint: aHR0cDovL3MzLnNoMWEucWluZ3N0b3IuY29t
s3-access-key: Vk5YWUhZSFFVWFpLVVZaRkdGUlk=
s3-secret-key: MHp3N0pLa2JBQWRsUUtIUGpUSFd0b0ZHR1FSdm5RNVNKUmM1UDY5cg==
s3-bucket: cmFkb25kYi1teXNxbC1idWNrZXQ=
type: Opaque

然后在 kubernetes 中执行创建加密配置。

$ kubectl create -f config/samples/backup_secret.yaml

步骤 4:创建及启动集群

请在mysql_v1a1pha1_mysqlcluster.yaml 文件中添加 backupSecretName 属性。

spec:
replicas: 3
mysqlVersion: "5.7"
backupSecretName: sample-backup-secret
...

执行以下指令,即创建 RadonDB MySQL 集群。

$ kubectl apply -f config/samples/mysql_v1alpha1_mysqlcluster.yaml

备份恢复

将集群数据备份到 S3 存储

创建备份文件 mysql_v1a1pha1_backup.yaml 内容如下。

apiVersion: mysql.radondb.com/v1alpha1
kind: Backup
metadata:
name: backup-sample1
spec:
# Add fields here
hostname: sample-mysql-0
clustname: sample
name function
hostname pod name in cluser
clustname cluster name

待集群运行成功后,执行以下指令开始备份。

$ kubectl apply -f config/samples/mysql_v1alpha1_backup.yaml

备份完成后可在 S3 查看对应的备份文件。

从 S3 备份中恢复集群

检测你的 S3 bucket,获取你备份的目录,比如:backup_2021720827,并且将设置为 yaml 文件的 restoreFrom 属性中。

...
spec:
replicas: 3
mysqlVersion: "5.7"
backupSecretName: sample-backup-secret
restoreFrom: "backup_2021720827"
...

此时执行以下指令:

$ kubectl apply -f config/samples/mysql_v1alpha1_mysqlcluster.yaml

恢复完成,已经从名为 backup_2021720827 的 S3 备份中恢复一个集群。

卸载

卸载过程详见《部署文档》 的卸载部分。

推荐阅读

  • RadonDB MySQL on Kubernetes 2.1.3 发布!
  • 容器化 | K8s 部署 RadonDB MySQL Operator 和集群

容器化|在 S3 备份恢复 RadonDB MySQL 集群数据相关推荐

  1. mysql集群数据引擎_MySQL数据引擎

    InnoDB存储引擎 该引擎是MySQL数据库的默认事务型引擎,它被设计用来处理大量短期事务(绝大多数正常提交,很少回滚) InnoDB的数据存储在表空间中,表空间是由InnoDB管理的一个黑盒子,由 ...

  2. elasticsearch备份恢复(单机集群)

    参考:https://www.elastic.co/guide/en/elasticsearch/reference/7.3//modules-snapshots.html#_snapshot 简单记 ...

  3. 阿里巴巴mysql集群方案_云原生下,如何实现高可用的MySQL?

    简介: MySQL 作为当前比较受欢迎的关系型数据库(RDS),在云原生浪潮中仍然面临诸多挑战.如何用 Cloud Native 的设计原则,通过沙箱隔离.计算和数据的完全分离,实现低成本.可扩展.高 ...

  4. MySQL集群节点参数说明

    1. 定义MySQL集群管理服务器 [NDB_MGMD]部分(或其别名[MGM])用于配置管理服务器的行为.下面列出的所有参数均能被忽略,如果是这样,将使用其默认值.注释:如果ExecuteOnCom ...

  5. rancher安装mysql_四、rancher搭建Mysql集群化部署,做到同步备份

    一.Rancher基础镜像查找: 1.基础镜像操作地址:https://hub.docker.com/r/library/mariadb/ 2.选择自己需要的镜像进行搜索,里面有对应版本:也有最新的如 ...

  6. mysql galera 恢复_galera mariadb集群恢复策略

    1 galera mariadb 首先MariaDB是一个数据库,可以看成是MySQL的一个分支,由于MySQL被SUN收购,所以MySQL面临着闭源的风险,当时MySQL之父Widenius并没有加 ...

  7. kubernetes怎么读_Kubernetes之有状态应用实践-搭建MySQL集群

    零.前情纪要 上一遍文章Kubernetes集群搭建已经带大家成功搭建了Kubernetes集群,可能有不少人在搭建过程中对很多概念性的东西还是很模糊,接下来这篇文章将通过带领大家一起搭建一个高可用的 ...

  8. mysql 集群_MySQL之PXC集群搭建

    一.PXC 介绍 1.1 PXC 简介 PXC 是一套 MySQL 高可用集群解决方案,与传统的基于主从复制模式的集群架构相比 PXC 最突出特点就是解决了诟病已久的数据复制延迟问题,基本上可以达到实 ...

  9. 如何在Ubuntu 18.04上创建多节点MySQL集群

    翻译转载:https://www.digitalocean.com/community/tutorials/how-to-create-a-multi-node-mysql-cluster-on-ub ...

最新文章

  1. ef 在此上下文中只支持基本类型或枚举类型_Java 中的 6 颗语法糖
  2. SuperSocket 服务管理器 (ServerManager)
  3. 捷易拍sdk开发指南.doc_每个Android开发都必须知道的利器
  4. jmeter 加密解密_使用Jmeter对SHA1加密接口进行性能测试
  5. sqlite管理工具_Liquibase 数据库版本管理工具:1.安装
  6. aix解锁oracle用户,aix用户被锁定的解决办法
  7. 【VB.NET】测验题目Quiz2
  8. DecimalFormat的几种用法!关于字符串的使用
  9. Halcon 缺陷检测概述
  10. java统计中英文字数 Java问题通用解决代码
  11. 我自己的 psftp-cmd
  12. android 4.x tablet,Android SmartPhone应用程序对Android Tablet的支持
  13. 如何培养一个人:从育儿谈起
  14. 双稳态继电器工作原理图_一种双稳态继电器的制作方法
  15. fluent linux运行算例,在linux环境下运行fluent,case文件中带有udf的话,jou文件应该做什么改变呢?...
  16. Python引号的用法
  17. 我为你写下悲伤的文字:伤感心情随笔
  18. Linux命令之expr详解
  19. 【educoder 机器学习】决策树
  20. 如何布置项目到远程服务器上,如何用远程服务器布置项目

热门文章

  1. 牛客java选择题每日打卡Day5
  2. 线阵CCD FPGA CCD测量 直径测量 FPGA代码 CCD光学传感器 TCD1501
  3. 数据库中distinct关键字的使用
  4. 旅游网站的设计与制作
  5. 自定义View 篇四《低仿QQ测拉删除》
  6. Android入门(1) 安卓相关概念及版本
  7. Django 2.1.3 文档-模板-内置标签和过滤器(tagfilter)
  8. 网易云信音视频能力中台,聚焦银行业数字化转型
  9. windows xp主题不见了
  10. tomcat 启动报端口被占用(windows)