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)
相关推荐
czhc11400756631 小时前
c# 1213
开发语言·数据库·c#
voltina1 小时前
【SQL】【事务】
数据库·sql
古渡蓝按2 小时前
PostgreSQL数据库在Windows上实现异地自动备份指南-喂饭图文教程
数据库
她说..2 小时前
MySQL数据处理(增删改)
java·开发语言·数据库·mysql·java-ee
E***U9452 小时前
从新手到入门:如何判断自己是否真的学会了 Spring Boot
数据库·spring boot·后端
Alex Gram2 小时前
MySQL实时同步到SQL Server:技术方案与实现路径
数据库·mysql
不穿格子的程序员2 小时前
Redis篇3——Redis深度剖析:内存数据的“不死之身”——RDB、AOF与混合持久化
数据库·redis·缓存·数据持久化·aof·rdb
秋深枫叶红2 小时前
嵌入式第三十四篇——linux系统编程——进程
linux·服务器·数据库·学习
贡献者手册3 小时前
SQLite 的进阶版,面向边缘计算、嵌入式场景的高性能本地数据库【Turso Database】
数据库
TH_13 小时前
6、前台界面传递老数据,导致业务数据错误
数据库