Mysql差异备份与恢复

1.练习差异备份

差异备份:备份完全备份后,新产生的数据。

在192.168.88.50主机完成差异备份

bash 复制代码
步骤一:练习差异备份

//周一完全备份
mysql> select * from test.one;
+---------+------+------+
| name    | age  | sex  |
+---------+------+------+
| 测试    |   10 | 男   |
| 测试1   |   11 | 女   |
| 测试2   |   11 | 女   |
| 测试3   |   11 | 女   |
| 测试4   |   11 | 女   |
| 测试5   |   11 | 女   |
| 测试6   |   11 | 女   |
| 测试7   |   11 | 女   |
+---------+------+------+
8 rows in set (0.00 sec)
[root@mysql150 ~]# xtrabackup --host=127.0.0.1 --user=root --password=123456 --backup --target-dir=/alldir --datadir=/var/lib/mysql
//插入新数据 (可以插入多行)
mysql> insert into test.one values ('测试8',11,'女');

//周二差异备份,备份周一备份后新产生的数据
[root@mysql150 ~]# xtrabackup --host=127.0.0.1 --user=root --password=123456 --backup --target-dir=/dir2 --incremental-basedir=/alldir --datadir=/var/lib/mysql
mysql> insert into test.one values ('测试9',11,'女');

//周三差异备份,备份周一备份后新产生的数据
[root@mysql150 ~]# xtrabackup --host=127.0.0.1 --user=root --password=123456 --backup --target-dir=/dir3 --incremental-basedir=/alldir --datadir=/var/lib/mysql
mysql> insert into test.one values ('测试10',11,'女');

//周四差异备份,备份周一备份后新产生的数据
[root@mysql150 ~]# xtrabackup --host=127.0.0.1 --user=root --password=123456 --backup --target-dir=/dir4 --incremental-basedir=/alldir --datadir=/var/lib/mysql
mysql> insert into test.one values ('测试11',11,'女');

//周五差异备份,备份周一备份后新产生的数据
[root@mysql150 ~]# xtrabackup --host=127.0.0.1 --user=root --password=123456 --backup --target-dir=/dir5 --incremental-basedir=/alldir --datadir=/var/lib/mysql
mysql> insert into test.one values ('测试12',11,'女');

//周六差异备份,备份周一备份后新产生的数据
[root@mysql150 ~]# xtrabackup --host=127.0.0.1 --user=root --password=123456 --backup --target-dir=/dir6 --incremental-basedir=/alldir --datadir=/var/lib/mysql
mysql> insert into test.one values ('测试13',11,'女');

//周日差异,备份备份周一备份后新产生的数据
[root@mysql150 ~]# xtrabackup --host=127.0.0.1 --user=root --password=123456 --backup --target-dir=/dir7 --incremental-basedir=/alldir --datadir=/var/lib/mysql

2.练习差异恢复

差异恢复数据步骤:

  1. 准备恢复数据
  2. 合并数据
  3. 清空数据库目录
  4. 拷贝数据
  5. 修改数据库目录所有者/组用户为mysql
  6. 重启数据库服务

具体操作如下:

bash 复制代码
把MySQL150的备份文件拷贝给MySQL151
[root@mysql150 ~]# scp -r /alldir/ root@192.168.10.151:/root
[root@mysql150 ~]# scp -r /dir7  root@192.168.10.151:/root

151主机操作
准备恢复数据
[root@mysql151 ~]# xtrabackup --prepare --apply-log-only --target-dir=/root/alldir
合并数据
说明:将周日的差异备份与周一的完全备份合并,因为周日的差异备份包扩周二+周日的所有数据
[root@mysql151 ~]# xtrabackup --prepare --apply-log-only --target-dir=/root/alldir --incremental-dir=/root/dir7
完成事务处理并使备份可恢复
[root@mysql151 ~]# xtrabackup --prepare --target-dir=/root/alldir
清空数据库目录
[root@mysql151 ~]# rm -rf /var/lib/mysql/*
拷贝数据
[root@mysql151 ~]# xtrabackup --copy-back --target-dir=/root/alldir 
调整文件权限
[root@mysql151 ~]# chown -R mysql:mysql /var/lib/mysql
启动 MySQL 服务
[root@mysql151 ~]# systemctl restart mysqld
[root@mysql151 ~]# mysql -uroot -p123456
mysql> select * from test.one;
+----------+------+------+
| name     | age  | sex  |
+----------+------+------+
| 测试     |   10 | 男   |
| 测试1    |   11 | 女   |
| 测试2    |   11 | 女   |
| 测试3    |   11 | 女   |
| 测试4    |   11 | 女   |
| 测试5    |   11 | 女   |
| 测试6    |   11 | 女   |
| 测试7    |   11 | 女   |
| 测试8    |   11 | 女   |
| 测试9    |   11 | 女   |
| 测试10   |   11 | 女   |
| 测试11   |   11 | 女   |
| 测试12   |   11 | 女   |
| 测试13   |   11 | 女   |
+----------+------+------+
14 rows in set (0.01 sec)
相关推荐
听*雨声10 分钟前
软件设计师上午题5:数据库
数据库
hong781720 分钟前
阿里coding plan qwen3.6-plus 不支持图片上下文长度只有200K,问题出在哪?
linux·运维·数据库
Paxon Zhang1 小时前
MySQL 大师之路**数据库约束,表设计,CRUD**
android·数据库·mysql
HealthScience1 小时前
clinvar数据集说明
数据库·oracle
王的宝库1 小时前
【MySQL】主从复制原理详解:从 Binlog 到数据一致性
数据库·mysql
Vect__1 小时前
MySQL基本认知、库和表的操作
数据库·mysql
cyber_两只龙宝1 小时前
【Oracle】Oracle之DQL中SELECT的基础使用
linux·运维·服务器·数据库·云原生·oracle
老苏畅谈运维1 小时前
Oracle 在线表重定义:将非分区表转换为分区表的最佳实践
数据库·oracle
treacle田1 小时前
达梦数据库-达梦数据库中link链接访问oracle 19c/11g-记录总结
数据库·oracle·达梦 link访问oracle
萌兰三太子1 小时前
RAG 向量数据库设计指南:从入门到生产
数据库·oracle