xtrabackup 对pxc节点进行备份恢复
xtrabackup 对pxc节点进行备份恢复
全量备份一个节点的数据,当节点挂掉时,使用备份恢复到最近状态,再启动节点加入集群。
备份
xtrabackup 命令小解释:
--defaults-file=/etc/my.cnf : 指定pxc配置文件,默认/etc/my.cnf,手动指定该参数需要置于第一位,此配置文件里必须指定datadir
--user=root : 用户
--password=*** : 密码
--socket=/tmp/mysql-pxc.sock : sock 文件
--target-dir=/data/backup/ : 指定备份路径,不存在会自动创建
--backup : 进行备份时使用的参数
--stream=tar : 指定压缩模式,tar、xbstream
--prepare : 执行数据文件拷贝前的动作,同innobackup 的 --apply-log。一般情况下,在备份完成后,数据尚且不能用于恢复操作,因为备份的数据中可能会包含尚未提交的事务或已经提交但尚未同步至数据文件中的事务。因此,此时数据 文件仍处理不一致状态。该参数的作用是通过回滚未提交的事务及同步已经提交的事务至数据文件使数据文件处于一致性状态。
--copy-back : 拷贝数据文件到datadir中,你开心用mv、cp、rsync都行
--galera-info : 记录集群的uuid和最后提交的事物seqno
实际环境中,可能很多参数都不需要。
本地备份:
/usr/bin/xtrabackup --defaults-file=/etc/my.cnf --user=root --password=**** --socket=/tmp/mysql-pxc.sock --backup --galera-info --target-dir=/data/backup/all_db_backup
本地压缩备份:
/usr/bin/xtrabackup --defaults-file=/etc/my.cnf --user=root --password=**** --socket=/tmp/mysql-pxc.sock --backup --galera-info --target-dir=/data/backup/ --stream=tar > all_db_backup.tar.gz
远程备份:
/usr/bin/xtrabackup --defaults-file=/etc/my.cnf --user=root --password=**** --socket=/tmp/mysql-pxc.sock --backup --galera-info --target-dir=/data/backup/ --stream=tar | ssh -p 22 -o StrictHostKeyChecking=no 172.16.11.216 "cat -> /data/backup/all_db_backup.tar.gz"
# 或者
/usr/bin/xtrabackup --defaults-file=/etc/my.cnf --user=root --password=`cat /data/save/mysql_root` --socket=/tmp/mysql-pxc.sock --backup --galera-info --target-dir=/data/backup/ --stream=xbstream | ssh -p 22 -o StrictHostKeyChecking=no 172.16.11.216 "/usr/bin/xbstream -x -C /data/backup/"
恢复
我们假设节点已经down了,那就直接把节点datadir清空吧。
rm -rf /data/database/mysql/*
# 如果是压缩备份,解压前加个 -i 参数
tar -ixf all_db_backup.tar.gz -C /data/backup/all_db_backup
# 先prepare
/usr/bin/xtrabackup --defaults-file=/etc/my.cnf --prepare --target-dir=/data/backup/all_db_backup
# 再copyback
xtrabackup --defaults-file=/etc/my.cnf --copy-back --target-dir=/data/backup/all_db_backup
需要借助xtrabackup_galera_info 中的uuid和seqno来实现以IST的方式加入集群:
#配置grastate.dat
cat /data/database/pxc3306/xtrabackup_galera_info
bf26341f-43cb-11e8-a863-62c0eb4d9e79:728[
vim /data/database/pxc3306/grastate.dat
LERA saved state
# GALERA saved state
version: 2.1
uuid: bf26341f-43cb-11e8-a863-62c0eb4d9e79
seqno: 728
safe_to_bootstrap: 0
# 授权
chown mysql:mysql -R /data/database/mysql
# 查看其它节点中,gcacche缓存的最小seqno
(root@localhost) [(none)]> show status like 'wsrep_local_cached_downto';
+---------------------------+-------+
| Variable_name | Value |
+---------------------------+-------+
| wsrep_local_cached_downto | 693 |
+---------------------------+-------+
1 row in set (0.01 sec)
其它节点的gcache缓存的最小seqno为693,而宕机节点的为728,可以直接启动以ist的方式加入集群:
/etc/init.d/mysql start
这样就可以使用备份数据恢复节点,启动后集群会选举一个节点作为Donor,以IST的方式同步新增的数据。
xtrabackup 对pxc节点进行备份恢复的更多相关文章
- mysql 开发进阶篇系列 47 物理备份与恢复(xtrabackup 的完全备份恢复,恢复后重启失败总结)
一. 完全备份恢复说明 xtrabackup二进制文件有一个xtrabackup --copy-back选项,它将备份复制到服务器的datadir目录下.下面是通过 --target-dir 指定完全 ...
- Kubernetes Master节点灾备恢复操作指南---升级版
本文档简述了Kubernetes主节点灾备恢复的相关步骤,供在发生k8s master崩溃时操作. 就算是在k8s里部署了etcd群集, 主节点控制组件的高可用节点,灾备恢复也是必须要实现的操作,才能 ...
- Xtrabackup原理及使用innobackupex进行MySQL数据库备份恢复
Xtrabackup是由percona提供的mysql数据库备份工具,据官方介绍,这也是世界上惟一一款开源的能够对innodb和xtradb数据库进行热备的工具. Xtrabackup中主要包含两个工 ...
- 从xtrabackup备份恢复单表【转】
目前对MySQL比较流行的备份方式有两种,一种上是使用自带的mysqldump,另一种是xtrabackup,对于数据时大的环境,普遍使用了xtrabackup+binlog进行全量或者增量备份,那么 ...
- xtrabackup 备份恢复
XtraBackup物理备份 Percona XtraBackup是世界上唯一的开源,免费的MySQL热备份软件,为InnoDB和XtraDB 数据库执行非阻塞备份.使用Percona XtraBac ...
- MySQL | 使用Xtrabackup进行备份和备份恢复
备份 进行备份前需要先创建备份用户,直接使用 root 用户进行备份也行,但是这样不太规范. create user backup@'localhost' identified by '123456' ...
- (转)解锁MySQL备份恢复的4种正确姿势
本文根据DBAplus社群第104期线上分享整理而成. 原文:http://dbaplus.cn/news-11-1267-1.html 讲师介绍 冯帅 点融网高级DBA 获有Oracle OCM ...
- 基于MySQL MEB的备份恢复
MEB(MySQL Enterprise Backup)是MySQL商业版中提供的备份工具,属于物理备份. 同XtraBackup一样,mysqlbackup的使用过程同样包含如下三个步骤: 备份(- ...
- 使用 xtrabackup 进行MySQL数据库物理备份
0. xtrabackup的功能 能实现的功能: 非阻塞备份innodb等事务引擎数据库. 备份myisam表会阻塞(需要锁). 支持全备.增量备份.压缩备份. 快速增量备份(xtradb,原理类似于 ...
随机推荐
- Java 基础 常用API (Object类,String类,StringBuffer类)
Java API Java 的API(API: Application(应用) Programming(程序) Interface(接口)) Java API就是JDK中提供给我们使用的类,这些类将底 ...
- [LeetCode] 586. Customer Placing the Largest Number of Orders_Easy tag;SQL
Query the customer_number from the orders table for the customer who has placed the largest number o ...
- SEO--简介
SEO:搜索引擎优化 不需付费 SEM:搜索引擎营销 需要付费 IP:每个家庭每个公司应该是同个IP PV:网站刷新搜索总量 UV:独立用户访客
- vue2.0项目中 localhost改成ip地址访问
这里 你可以写成你的ip 那你的项目只能ip访问了,但是写成0.0.0.0的话 你既可已localhost 访问也可以ip访问 也可以写成 127.0.0.1也可以,也能local访问了和ip访问( ...
- uft调用rfc接口
RFC接口函数调用: 以下代码是封装好的,为了提供给UFT工具调用,使用c#写成dll. 类型项目分成两个: 1.baseConfigModel.cs //sap配置登录信息,属性实体类 using ...
- MyBatis基础入门《五》核心配置文件
MyBatis基础入门<五>核心配置文件 描述: 在前面的章节中,简单的学习使用了一下mybatis,对于配置文件没有过多详细说明. 这里先描述项目中的一个核心配置文件:mybatis-c ...
- 2-2:python之控制结构
一.程序流程图 1.用规定的一系列图形.流程线和文字说明算法从开始到结束全部步骤,包括基本操作和控制流程.2.流程图的基本元素包括: 1) 表示相应操作的框 2) 带箭头的流程线 3) 框内必要的文 ...
- Quick-Cocos2d-x 新建项目
开发工具准备就绪以后,下面我们就可以开始创建我们的项目了. 首先启动 Quick 下的 player3,在这儿的示例标签下你可以看到很多Quick自带的示例,对于初学者来说,看看这些示例的使用方法会对 ...
- 【Hive学习之五】Hive 参数&动态分区&分桶
环境 虚拟机:VMware 10 Linux版本:CentOS-6.5-x86_64 客户端:Xshell4 FTP:Xftp4 jdk8 hadoop-3.1.1 apache-hive-3.1.1 ...
- 刨根究底字符编码之—UTF-16编码方式
在网上已经转悠好几天了, 这篇文章让我知道了UTF-16的前世今生, 感谢作者https://cloud.tencent.com/developer/article/1384687 1. UTF-16 ...