完全备份、增量备份、差异备份、binlog日志

1 案例1:完全备份与恢复

1.1 问题

  1. 练习物理备份与恢复
  2. 练习mysqldump备份与恢复

1.2 方案

在数据库服务器192.168.88.50 练习数据的备份与恢复

1.3 步骤

实现此案例需要按照如下步骤进行。

步骤一:练习物理备份与恢复

冷备份,需停止数据库服务 适合线下服务器。

备份数据

    [root@mysql50 ~]# systemctl  stop  mysqld
    [root@mysql50 ~]# mkdir /bakdir  创建备份目录
    [root@mysql50 ~]# cp -r /var/lib/mysql /bakdir/mysql.bak 拷贝数据源文件
    [root@mysql50 ~]# cd /var/lib/mysql
    [root@mysql50 mysql]# tar -zcvf /bakdir/mysql.tar.gz ./*  打包压缩数据源文件
    [root@mysql50 mysql]# ls /bakdir/  查看备份文件
    mysql.bak  mysql.tar.gz

删除数据

    [root@mysql50 ~]# rm -rf /var/lib/mysql/* 

恢复数据

    [root@mysql50 ~]# tar -xf /bakdir/mysql.tar.gz  -C /var/lib/mysql/
    [root@mysql50 ~]# systemctl  start mysqld
    [root@mysql50 ~]# mysql -uroot -pNSD2023...a
     mysql> show databases;
    +--------------------+
    | Database           |
    +--------------------+
    | GAMEDB             |
    | db1                |
    | home               |
    | information_schema |
    | mysql              |
    | performance_schema |
    | studb              |
    | sys                |
    | tarena             |
    | 学生库             |
    +--------------------+
    10 rows in set (0.00 sec)

也可使用cp拷贝的备份文件恢复数据

    [root@mysql50 ~]# systemctl  stop  mysqld
    [root@mysql50 ~]# rm -rf /var/lib/mysql/*
    [root@mysql50 ~]# cp -r /bakdir/mysql.bak/* /var/lib/mysql/
    [root@mysql50 ~]# chown  -R mysql:mysql /var/lib/mysql
    [root@mysql50 ~]# systemctl  start mysqld
    [root@mysql50 ~]# mysql -uroot -pNSD2023...a

步骤二:练习mysqldump备份与恢复

热备份,备份和恢复数据库服务必须是运行的

    //备份1张表 
    [root@mysql50 ~]# mysqldump -uroot -pNSD2023...a  tarena salary > /bakdir/tarena_salary.sql
    mysqldump: [Warning] Using a password on the command line interface can be insecure.
    //备份多张表
    [root@mysql50 ~]# mysqldump -uroot -pNSD2023...a  tarena employees departments > /bakdir/tarena_employees_deparments.sql
    mysqldump: [Warning] Using a password on the command line interface can be insecure.
    //备份1个库 
    [root@mysql50 ~]# mysqldump -uroot -pNSD2023...a  -B tarena > /bakdir/tarena.sql 
    mysqldump: [Warning] Using a password on the command line interface can be insecure.
    //备份多个库
    [root@mysql50 ~]# mysqldump -uroot -pNSD2023...a  -B studb db1 > /bakdir/studb_db1.sql 
    mysqldump: [Warning] Using a password on the command line interface can be insecure.
    //备份所有库 
    [root@mysql50 ~]# mysqldump -uroot -pNSD2023...a  -A  > /bakdir/allbak.sql 
    mysqldump: [Warning] Using a password on the command line interface can be insecure.
    [root@mysql50 ~]# 

恢复数据(覆盖恢复数据)

    [root@mysql50 ~]# mysql -uroot -pNSD2023...a
    mysql> drop  database tarena; //删除库
    Query OK, 6 rows affected (0.57 sec)
    mysql> exit
    Bye
    [root@mysql50 ~]# mysql -uroot -pNSD2023...a < /bakdir/tarena.sql //恢复数据
    mysql: [Warning] Using a password on the command line interface can be insecure.
    [root@mysql50 ~]# mysql -uroot -pNSD2023...a //登陆
    mysql> use tarena; //进库
    mysql> show tables; //看表
    +------------------+
    | Tables_in_tarena |
    +------------------+
    | departments      |
    | employees        |
    | salary           |
    | stu4             |
    | user             |
    | wage_grade       |
    +------------------+
    6 rows in set (0.00 sec)
    mysql> delete from salary; //删除表记录
    Query OK, 8055 rows affected (0.11 sec)
    mysql> exit
    Bye
    [root@mysql50 ~]#
    //使用备份文件恢复数据
    [root@mysql50 ~]# mysql -uroot -pNSD2023...a  tarena < /bakdir/tarena_salary.sql 
    mysql: [Warning] Using a password on the command line interface can be insecure.
    [root@mysql50 ~]# mysql -uroot -pNSD2023...a //登陆服务
    mysql> select count(*) from tarena.salary; //查看行数
    +----------+
    | count(*) |
    +----------+
    |     8055 |
    +----------+
    1 row in set (0.00 sec)

分析:

Mysqldump 备份和恢复数据时会锁表,锁表期间无法对表做写访问,mysqldump适合备份数据量比较小的数据或在数据库服务器访问量少的时候备份。

2 案例2:增量备份与恢复

2.1 问题

  1. 练习数据增量备份
  2. 练习数据增量恢复

2.2 方案

2.3 准备2台数据库服务器,如表-1所示

增量备份:备份上次备份后,新产生的数据。

PERCONA Xtrabackup是一款强大的在线热备份工具,备份过程中不锁库表,适合生产环境。支持完全备份与恢复、增量备份与恢复、差异备份与恢复。

在192.168.88.50主机完成备份与恢复的练习 。

2.4 步骤

实现此案例需要按照如下步骤进行。

步骤一:练习数据增量备份

安装软件(在mysql50 、MySQL51 两台主机都要安装)

    //把软件拷贝到虚拟机里
    [openeuler@server1 ~]$ scp /linux-soft/s3/percona-xtrabackup-8.0.26-18-Linux-x86_64.glibc2.12-minimal.tar.gz root@192.168.88.50:/root/ 
    //安装依赖
    [root@host50 ~]# yum -y  install perl-DBD-MySQL
    //解压源码
    [root@host50 ~ ]# tar -xf percona-xtrabackup-8.0.26-18-Linux-x86_64.glibc2.12-minimal.tar.gz
    //移动并改名
    [root@host50 ~ ]# mv percona-xtrabackup-8.0.26-18-Linux-x86_64.glibc2.12-minimal /usr/local/percona
    //把命令添加到系统环境变量
    [root@host50 ~ ]# vim /etc/bashrc
    export PATH=/usr/local/percona/bin:$PATH  添加在文件末尾
    :wq
    [root@host50 ~ ]# source  /etc/bashrc
    //查看帮助信息
    [root@host50 ~ ]# man xtrabackup (按q 退出)

增量备份(在mysql50主机 完成增量备份练习)

对数据做增量备份前,必须先有一次备份,也就是首次备份,通常是备份所有数据;比如每周周一完全备份,周二到周日增量备份。

周一完全备份(备份所有数据)

    [root@mysql50 ~]# xtrabackup --host=127.0.0.1 --user=root --password=NSD2023...a --backup --target-dir=/fullbak --datadir=/var/lib/mysql
    ......
    ......
    230530 18:18:48 [00]        ...done
    xtrabackup: Transaction log of lsn (24822878) to (24822898) was copied.
    230530 18:18:50 completed OK!
    [root@mysql50 ~]#
    //插入新数据 (可以插入多行)
    mysql> insert into tarena.salary(date,employee_id,basic,bonus)values("20230610",18,25000,8000);

周二增量备份(备份周一备份后新产生的数据)

    [root@mysql50 ~]# xtrabackup --host=127.0.0.1 --user=root --password=NSD2023...a --backup --target-dir=/new2 --incremental-basedir=/fullbak  --datadir=/var/lib/mysql
    ......
    ......
    230530 18:33:52 [00]        ...done
    xtrabackup: Transaction log of lsn (24827173) to (24827183) was copied.
    230530 18:33:53 completed OK!
    [root@mysql50 ~]#
    //插入新数据 (可以插入多行)
    mysql> insert into tarena.salary(date,employee_id,basic,bonus)values("20230710",18,25000,8000);

周三增量备份(备份周二备份后新产生的数据)

    [root@mysql50 ~]# xtrabackup --host=127.0.0.1 --user=root --password=NSD2023...a --backup --target-dir=/new3 --incremental-basedir=/new2  --datadir=/var/lib/mysql
    ......
    ......
    230530 18:46:17 [00]        ...done
    xtrabackup: Transaction log of lsn (24832526) to (24832536) was copied.
    230530 18:46:18 completed OK!
    [root@mysql50 ~]#
    //插入新数据 (可以插入多行)
    mysql> insert into tarena.salary(date,employee_id,basic,bonus)values("20230710",18,25000,8000);

周四增量备份(备份周三备份后新产生的数据)

    [root@mysql50 ~]# xtrabackup --host=127.0.0.1 --user=root --password=NSD2023...a --backup --target-dir=/new4 --incremental-basedir=/new3  --datadir=/var/lib/mysql
    ......
    ......
    230530 18:53:41 [00]        ...done
    xtrabackup: Transaction log of lsn (24837561) to (24837571) was copied.
    230530 18:53:42 completed OK!
    [root@mysql50 ~]#
    //插入新数据 (可以插入多行)
    mysql> insert into tarena.salary(date,employee_id,basic,bonus)values("20230710",18,25000,8000);

周五增量备份(备份周四备份后新产生的数据)

    [root@mysql50 ~]# xtrabackup --host=127.0.0.1 --user=root --password=NSD2023...a --backup --target-dir=/new5 --incremental-basedir=/new4  --datadir=/var/lib/mysql
    ......
    ......
    230530 18:58:50 [00]        ...done
    xtrabackup: Transaction log of lsn (24841645) to (24841655) was copied.
    230530 18:58:51 completed OK!
    [root@mysql50 ~]#
    //插入新数据 (可以插入多行)
    mysql> insert into tarena.salary(date,employee_id,basic,bonus)values("20230710",18,25000,8000);

周六增量备份(备份周五备份后新产生的数据)

    [root@mysql50 ~]# xtrabackup --host=127.0.0.1 --user=root --password=NSD2023...a --backup --target-dir=/new6 --incremental-basedir=/new5  --datadir=/var/lib/mysql
    ......
    ......
    230530 19:00:55 [00]        ...done
    xtrabackup: Transaction log of lsn (24848404) to (24848414) was copied.
    230530 19:00:56 completed OK!
    [root@mysql50 ~]#
    //插入新数据 (可以插入多行)
    mysql> insert into tarena.salary(date,employee_id,basic,bonus)values("20230710",18,25000,8000);

步骤二:练习数据增量恢复

增量恢复数据步骤:

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

具体操作如下:

MySQL51 拷贝 MySQL50 的备份文件到 本机的根目录下

    [root@mysql51 ~]# scp --r  root@192.168.88.50:/fullbak  /
    [root@mysql51 ~]# scp --r  root@192.168.88.50:/new2  /
    [root@mysql51 ~]# scp --r  root@192.168.88.50:/new3  /
    [root@mysql51 ~]# scp --r  root@192.168.88.50:/new4  /
    [root@mysql51 ~]# scp --r  root@192.168.88.50:/new5  /
    [root@mysql51 ~]# scp --r  root@192.168.88.50:/new6  /
    [root@mysql51 ~]# scp --r  root@192.168.88.50:/new7  /

在MySQL51主机使用备份文件恢复数据

1)、准备恢复数据

    [root@mysql51 ~]# xtrabackup --prepare --apply-log-only --target-dir=/fullbak
    ......
    ......
    Log background threads are being closed...
    Shutdown completed; log sequence number 24822898
    Number of pools: 1
    230531 14:32:14 completed OK!
    [root@mysql51 ~]#

2)、合并数据

    //将周二的增量数据拷贝到周一备份目录里,合并后周一的目录里存放的是周一 + 周二 的数据
    [root@mysql51 ~]# xtrabackup --prepare --apply-log-only --target-dir=/fullbak --incremental-dir=/new2
    ......
    ......
    230531 14:40:05 [00] Copying /new2/binlog.index to ./binlog.index
    230531 14:40:05 [00]        ...done
    230531 14:40:05 completed OK!
    [root@mysql51 ~]#
    //将周三的增量数据拷贝到周一备份目录里,合并后周一的目录里存放的是周一 + 周二 + 周三 的数据
    [root@mysql51 ~]# xtrabackup --prepare --apply-log-only --target-dir=/fullbak --incremental-dir=/new3
    ......
    ......
    230531 15:00:37 [00] Copying /new3/binlog.index to ./binlog.index
    230531 15:00:37 [00]        ...done
    230531 15:00:37 completed OK!
    [root@mysql51 ~]#
    //将周四的增量数据拷贝到周一备份目录里,合并后周一的目录里存放的是周一 + 周二 + 周三 +周四的数据
    [root@mysql51 ~]# xtrabackup --prepare --apply-log-only --target-dir=/fullbak --incremental-dir=/new4
    ......
    ......
    230531 15:00:37 [00] Copying /new4/binlog.index to ./binlog.index
    230531 15:00:37 [00]        ...done
    230531 15:00:37 completed OK!
    [root@mysql51 ~]#
    //将周五的增量数据拷贝到周一备份目录里,合并后周一的目录里存放的是周一 + 周二 + 周三 +周四+周五的数据
    [root@mysql51 ~]# xtrabackup --prepare --apply-log-only --target-dir=/fullbak --incremental-dir=/new5
    ......
    ......
    230531 15:00:37 [00] Copying /new5/binlog.index to ./binlog.index
    230531 15:00:37 [00]        ...done
    230531 15:00:37 completed OK!
    [root@mysql51 ~]#
    //将周六的增量数据拷贝到周一备份目录里,合并后周一的目录里存放的是周一 + 周二 + 周三 +周四+周五+周六的数据
    [root@mysql51 ~]# xtrabackup --prepare --apply-log-only --target-dir=/fullbak --incremental-dir=/new6
    ......
    ......
    230531 15:00:37 [00] Copying /new6/binlog.index to ./binlog.index
    230531 15:00:37 [00]        ...done
    230531 15:00:37 completed OK!
    [root@mysql51 ~]#
    //将周日的增量数据拷贝到周一备份目录里,合并后周一的目录里存放的是周一 + 周二 + 周三 +周四+周五+周六+周日的数据
    [root@mysql51 ~]# xtrabackup --prepare --apply-log-only --target-dir=/fullbak --incremental-dir=/new7
    ......
    ......
    230531 15:00:37 [00] Copying /new7/binlog.index to ./binlog.index
    230531 15:00:37 [00]        ...done
    230531 15:00:37 completed OK!
    [root@mysql51 ~]#
    [root@mysql51 ~]# rm -rf /var/lib/mysql/*
    [root@mysql51 ~]# xtrabackup --copy-back --target-dir=/fullbak
    [root@mysql51 ~]# chown -R mysql:mysql /var/lib/mysql

6)重启数据库服务

    [root@mysql51 ~]# systemctl  restart  mysqld

7)连接服务查看数据

    [root@mysql51 ~]# mysql -uroot -pNSD2023...a
    mysql> select count(*) from tarena.salary where date=20230710;
    +----------+
    | count(*) |
    +----------+
    |       75 |
    +----------+
    1 row in set (0.01 sec)
    mysql> select count(*) from tarena.salary where not  date=20230710;
    +----------+
    | count(*) |
    +----------+
    |     8067 |
    +----------+
    1 row in set (0.00 sec)

3 案例3:差异备份与恢复

3.1 问题

  1. 练习差异备份
  2. 练习差异恢复

3.2 方案

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

PERCONA Xtrabackup是一款强大的在线热备份工具,备份过程中不锁库表,适合生产环境。支持差异备份与恢复。

在192.168.88.50主机完成差异备份

3.3 步骤

实现此案例需要按照如下步骤进行。

步骤一:练习差异备份

差异备份

对数据做差异备份前,必须先有一次备份,也就是首次备份,通常是备份所有数据;比如每周周一完全备份,周二到周日差异备份。

    //周一完全备份
    [root@mysql50 ~]# xtrabackup --host=127.0.0.1 --user=root --password=NSD2023...a --backup --target-dir=/allbak --datadir=/var/lib/mysql
    ......
    ......
    230531 17:10:02 [00] Writing /allbak/xtrabackup_info
    230531 17:10:02 [00]        ...done
    xtrabackup: Transaction log of lsn (24881353) to (24881373) was copied.
    230531 17:10:03 completed OK!
    [root@mysql50 ~]# 
    //插入新数据 (可以插入多行)
    mysql> insert into tarena.salary(date,employee_id,basic,bonus)values("20230810",18,25000,8000);

周二差异备份,备份周一备份后新产生的数据

    [root@mysql50 ~]# xtrabackup --host=127.0.0.1 --user=root --password=NSD2023...a --backup --target-dir=/dir2 --incremental-basedir=/allbak --datadir=/var/lib/mysql
    ......
    ......
    230531 17:23:56 [00] Writing /dir2/xtrabackup_info
    230531 17:23:56 [00]        ...done
    xtrabackup: Transaction log of lsn (24886741) to (24886751) was copied.
    230531 17:23:58 completed OK!
    [root@mysql50 ~]# 
    //插入新数据 (可以插入多行)
    mysql> insert into tarena.salary(date,employee_id,basic,bonus)values("20230810",18,25000,8000);

周三差异备份,备份周一备份后新产生的数据

    [root@mysql50 ~]# xtrabackup --host=127.0.0.1 --user=root --password=NSD2023...a --backup --target-dir=/dir3 --incremental-basedir=/allbak  --datadir=/var/lib/mysql
    ......
    ......
    230531 17:27:10 [00] Writing /dir3/xtrabackup_info
    230531 17:27:10 [00]        ...done
    xtrabackup: Transaction log of lsn (24892043) to (24892063) was copied.
    230531 17:27:11 completed OK!
    [root@mysql50 ~]# 
    //插入新数据 (可以插入多行)
    mysql> insert into tarena.salary(date,employee_id,basic,bonus)values("20230810",18,25000,8000);

周四差异备份,备份周一备份后新产生的数据

    [root@mysql50 ~]# xtrabackup --host=127.0.0.1 --user=root --password=NSD2023...a --backup --target-dir=/dir4 --incremental-basedir=/allbak  --datadir=/var/lib/mysql
    ......
    ......
    230531 17:31:00 [00] Writing /dir4/xtrabackup_info
    230531 17:31:00 [00]        ...done
    xtrabackup: Transaction log of lsn (24900560) to (24900580) was copied.
    230531 17:31:01 completed OK!
    [root@mysql50 ~]# 
    //插入新数据 (可以插入多行)
    mysql> insert into tarena.salary(date,employee_id,basic,bonus)values("20230810",18,25000,8000);

周五差异备份,备份周一备份后新产生的数据

    [root@mysql50 ~]# xtrabackup --host=127.0.0.1 --user=root --password=NSD2023...a --backup --target-dir=/dir5 --incremental-basedir=/allbak  --datadir=/var/lib/mysql
    ......
    ......
    230531 17:32:38 [00] Writing /dir5/xtrabackup_info
    230531 17:32:38 [00]        ...done
    xtrabackup: Transaction log of lsn (24906902) to (24906912) was copied.
    230531 17:32:39 completed OK!
    [root@mysql50 ~]# 
    //插入新数据 (可以插入多行)
    mysql> insert into tarena.salary(date,employee_id,basic,bonus)values("20230810",18,25000,8000);

周六差异备份,备份周一备份后新产生的数据

    [root@mysql50 ~]# xtrabackup --host=127.0.0.1 --user=root --password=NSD2023...a --backup --target-dir=/dir6 --incremental-basedir=/allbak  --datadir=/var/lib/mysql
    ......
    ......
    230531 17:41:01 [00] Writing /dir6/xtrabackup_info
    230531 17:41:01 [00]        ...done
    xtrabackup: Transaction log of lsn (24914729) to (24914739) was copied.
    230531 17:41:02 completed OK!
    [root@mysql50 ~]#
    //插入新数据 (可以插入多行)
    mysql> insert into tarena.salary(date,employee_id,basic,bonus)values("20230810",18,25000,8000);

步骤二:练习差异恢复

差异恢复数据步骤:

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

具体操作如下:

MySQL51 拷贝 MySQL50 的备份文件到 本机的根目录下

    [root@mysql51 ~]# scp --r  root@192.168.88.50:/allbak  /
    [root@mysql51 ~]# scp --r  root@192.168.88.50:/dir7  /

在MySQL51主机使用备份文件恢复数据

1)、准备恢复数据

    [root@mysql51 ~]# xtrabackup --prepare --apply-log-only --target-dir=/allbak
    ......
    ......
    Log background threads are being closed...
    Shutdown completed; log sequence number 24881373
    Number of pools: 1
    230531 17:59:06 completed OK!
    [root@mysql51 ~]#

2)、合并数据

    //将周日的差异备份与周一的完全备份合并,因为周日的差异备份包扩周二+周日的所有数据
    [root@mysql51 ~]# xtrabackup --prepare --apply-log-only --target-dir=/allbak --incremental-dir=/dir7
    ......
    ......
    230531 18:05:08 [00] Copying /dir7/binlog.000029 to ./binlog.000029
    230531 18:05:08 [00]        ...done
    230531 18:05:08 [00] Copying /dir7/binlog.index to ./binlog.index
    230531 18:05:08 [00]        ...done
    230531 18:05:08 completed OK!
    [root@mysql51 ~]#
    [root@mysql51 ~]# rm -rf /var/lib/mysql/*
    [root@mysql51 ~]# xtrabackup --copy-back --target-dir=/allbak
    [root@mysql51 ~]# chown -R mysql:mysql /var/lib/mysql

6)重启数据库服务

    [root@mysql51 ~]# systemctl  restart  mysqld

7)连接服务查看数据

    [root@mysql51 ~]# mysql -uroot -pNSD2023...a
    mysql> select count(*) from tarena.salary where date=20230810;
    +----------+
    | count(*) |
    +----------+
    |       75 |
    +----------+
    1 row in set (0.01 sec)
    mysql> select count(*) from tarena.salary where not  date=20230810;
    +----------+
    | count(*) |
    +----------+
    |     8067 |
    +----------+
    1 row in set (0.00 sec)

4 案例4:binlog日志

4.1 问题

  1. 查看正在使用的binlog日志文件
  2. 自定义日志目录和日志名
  3. 手动创建新的日志文件
  4. 练习日志相关命令的使用
  5. 使用日志恢复数据

4.2 方案

binlog日志介绍:

  1. 也称做 二进制日志

  2. MySQL服务日志文件的一种

  3. 保存除查询之外的所有SQL命令

  4. 可用于数据的备份和恢复

  5. 配置mysql主从同步的必要条件

  6. 准备新的数据库服务器如表-1,做binlog日志的练习

    4.3 步骤

    实现此案例需要按照如下步骤进行。

    步骤一:查看正在使用的binlog日志文件

    在新创建的数据库服务器做如下操作:

        [root@mysql52 ~]# yum -y install mysql-server  mysql  安装软件 
        [root@mysql52 ~]# systemctl  start mysqld  启动服务
        [root@mysql52 ~]# mysql  连接服务
        mysql> show master status; 查看日志文件
        +----------------+----------+--------------+------------------+-------------------+
        | File           | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
        +----------------+----------+--------------+------------------+-------------------+
        | binlog.000001 |      156 |              |                  |                   |
        +----------------+----------+--------------+------------------+-------------------+
        1 row in set (0.00 sec)
        执行查询命令 
        mysql> select count(*) from  mysql.user;
        +----------+
        | count(*) |
        +----------+
        |        4 |
        +----------+
        1 row in set (0.00 sec)
        mysql> show master status; 执行查询命令 日志偏移量不变
        +----------------+----------+--------------+------------------+-------------------+
        | File           | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
        +----------------+----------+--------------+------------------+-------------------+
        | binlog.000001 |      156 |              |                  |                   |
        +----------------+----------+--------------+------------------+-------------------+
        1 row in set (0.00 sec)
        执行建库、建表命令
        mysql> create database  db1;
        Query OK, 1 row affected (0.07 sec)
        mysql> create table db1.user(name char(10));
        Query OK, 0 rows affected (0.52 sec)
        mysql> show master status; 执行写命令 日志偏移量改变
        +----------------+----------+--------------+------------------+-------------------+
        | File           | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
        +----------------+----------+--------------+------------------+-------------------+
        | binlog.000001 |      535 |              |                  |                   |
        +----------------+----------+--------------+------------------+-------------------+
        1 row in set (0.00 sec)
        mysql> insert into db1.user values("jim"); 插入记录
        Query OK, 1 row affected (0.10 sec)
        mysql> show master status; 执行写命令 日志偏移量改变
        +----------------+----------+--------------+------------------+-------------------+
        | File           | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
        +----------------+----------+--------------+------------------+-------------------+
        | binlog.000001 |      809 |              |                  |                   |
        +----------------+----------+--------------+------------------+-------------------+
        1 row in set (0.00 sec)
        mysql>
    

    步骤二:自定义日志目录和日志名

    日志文件默认保存在/var/lib/mysql目录下,默认日志名binlog

     [root@mysql52 ~]# vim /etc/my.cnf.d/mysql-server.cnf 
     [mysqld]
     log-bin=/mylog/mysql52   //定义日志目录和日志文件名(手动添加)
     :wq
     [root@mysql52 ~]# mkdir /mylog  创建目录
     [root@mysql52 ~]# chown  mysql  /mylog   修改目录所有者mysql用户
     [root@mysql52 ~]# setenforce  0   关闭selinux
     [root@mysql52 ~]# systemctl  restart mysqld   重启服务
     [root@mysql52 ~]# ls /mylog/  查看日志目录
     mysql52.000001  mysql52.index
     [root@mysql52 ~]# mysql  登陆服务
     Mysql> show master status ; 查看日志信息
     +----------------+----------+--------------+------------------+-------------------+
     | File           | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
     +----------------+----------+--------------+------------------+-------------------+
     | mysql52.000001 |      156 |              |                  |                   |
     +----------------+----------+--------------+------------------+-------------------+
    

步骤三:手动创建新的日志文件

默认日志文件容量大于1G时会自动创建新的日志文件,在日志文件没写满时,执行的所有写命令都会保存到当前使用的日志文件里。

    //刷新前查看
    mysql> show master status;
    +----------------+----------+--------------+------------------+-------------------+
    | File           | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
    +----------------+----------+--------------+------------------+-------------------+
    | mysql52.000001 |      156 |              |                  |                   |
    +----------------+----------+--------------+------------------+-------------------+
    1 row in set (0.00 sec)
    mysql> flush logs; //刷新日志
    Query OK, 0 rows affected (0.22 sec)
    mysql> flush logs; //刷新日志
    Query OK, 0 rows affected (0.16 sec)
    mysql> show master status; //刷新一次创建一个新日志
    +----------------+----------+--------------+------------------+-------------------+
    | File           | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
    +----------------+----------+--------------+------------------+-------------------+
    | mysql52.000003 |      156 |              |                  |                   |
    +----------------+----------+--------------+------------------+-------------------+
    1 row in set (0.00 sec)
    //只要服务重启就会创建新日志
    [root@mysql52 ~]# systemctl  restart mysqld 
    [root@mysql52 ~]# mysql  连接服务
    Mysql> show master status; 查看日志
    +----------------+----------+--------------+------------------+-------------------+
    | File           | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
    +----------------+----------+--------------+------------------+-------------------+
    | mysql52.000004 |      156 |              |                  |                   |
    +----------------+----------+--------------+------------------+-------------------+
    [root@mysql52 ~]#
    //完全备份后创建新的日志文件,创建的日志个数和备份库的个数一致
    [root@mysql52 ~]# mysqldump  --flush-logs  mysql user > user.sql
    [root@mysql52 ~]# mysql -e 'show master status'
    +----------------+----------+--------------+------------------+-------------------+
    | File           | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
    +----------------+----------+--------------+------------------+-------------------+
    | mysql52.000005 |      156 |              |                  |                   |
    +----------------+----------+--------------+------------------+-------------------+
    [root@mysql52 ~]# mysqldump  --flush-logs  -B mysql db1 > db_2.sql
    [root@mysql52 ~]# mysql -e 'show master status'
    +----------------+----------+--------------+------------------+-------------------+
    | File           | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
    +----------------+----------+--------------+------------------+-------------------+
    | mysql52.000007 |      156 |              |                  |                   |
    +----------------+----------+--------------+------------------+-------------------+
    [root@mysql52 ~]#

步骤四:练习日志相关命令的使用

MySQL服务提供了管理日志的专属命令,具体练习如下:

    //查看已有的日志文件
    mysql> show binary  logs;
    日志文件名        日志大小(字节)  加密(no/yes)
    +----------------+-----------+-----------+
    | Log_name       | File_size | Encrypted |
    +----------------+-----------+-----------+
    | mysql52.000001 |       201 | No        |
    | mysql52.000002 |       201 | No        |
    | mysql52.000003 |       179 | No        |
    | mysql52.000004 |       201 | No        |
    | mysql52.000005 |       201 | No        |
    | mysql52.000006 |       201 | No        |
    | mysql52.000007 |       156 | No        |
    +----------------+-----------+-----------+
    7 rows in set (0.00 sec)
    //查看正在使用的日志
    mysql> show master status;
    +----------------+----------+--------------+------------------+-------------------+
    | File           | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
    +----------------+----------+--------------+------------------+-------------------+
    | mysql52.000007 |      156 |              |                  |                   |
    +----------------+----------+--------------+------------------+-------------------+
    1 row in set (0.00 sec)
    //插入记录
    mysql> insert into db1.user values("yaya");
    Query OK, 1 row affected (0.04 sec)
    //查看日志文件内容
    mysql> show binlog events in  "mysql52.000007";
    Log_name:   日志文件名。
    Pos:         命令在日志文件中的起始位置。
    Event_type: 事件类型,例如 Query、Table_map、Write_rows 等。
    Server_id:  服务器 ID。
    End_log_pos:命令在文件中的结束位置,以字节为单位。
    Info:执行命令信息。
    +----------------+-----+----------------+-----------+-------------+--------------------------------------+
    | Log_name       | Pos | Event_type     | Server_id | End_log_pos | Info                                 |
    +----------------+-----+----------------+-----------+-------------+--------------------------------------+
    | mysql52.000007 |   4 | Format_desc    |         1 |         125 | Server ver: 8.0.26, Binlog ver: 4    |
    | mysql52.000007 | 125 | Previous_gtids |         1 |         156 |                                      |
    | mysql52.000007 | 156 | Anonymous_Gtid |         1 |         235 | SET @@SESSION.GTID_NEXT= 'ANONYMOUS' |
    | mysql52.000007 | 235 | Query          |         1 |         306 | BEGIN                                |
    | mysql52.000007 | 306 | Table_map      |         1 |         359 | table_id: 108 (db1.user)             |
    | mysql52.000007 | 359 | Write_rows     |         1 |         400 | table_id: 108 flags: STMT_END_F      |
    | mysql52.000007 | 400 | Xid            |         1 |         431 | COMMIT /* xid=649 */                 |
    +----------------+-----+----------------+-----------+-------------+--------------------------------------+
    7 rows in set (0.00 sec)
    //删除日志文件名之前的所有日志文件
    mysql> purge master logs  to  "mysql52.000004";
    Query OK, 0 rows affected (0.10 sec)
    //查看已有的日志文件
    mysql> show binary logs;
    +----------------+-----------+-----------+
    | Log_name       | File_size | Encrypted |
    +----------------+-----------+-----------+
    | mysql52.000004 |       201 | No        |
    | mysql52.000005 |       201 | No        |
    | mysql52.000006 |       201 | No        |
    | mysql52.000007 |       431 | No        |
    +----------------+-----------+-----------+
    4 rows in set (0.00 sec)
    //删除所有日志文件,并重新创建日志文件
    mysql> reset master;
    Query OK, 0 rows affected (0.14 sec)
    //查看已有的日志文件 ,仅有第1个文件了
    mysql> show binary logs;
    +----------------+-----------+-----------+
    | Log_name       | File_size | Encrypted |
    +----------------+-----------+-----------+
    | mysql52.000001 |       156 | No        |
    +----------------+-----------+-----------+
    1 row in set (0.00 sec)

步骤五:使用日志恢复数据

把查看到的文件内容管道给连接mysql服务的命令执行

恢复数据命令:

mysqlbinlog /目录/文件名 | mysql --uroot -p密码

1)在mysql52主机执行如下操:

    //重置日志
    mysql> reset master;
    Query OK, 0 rows affected (0.09 sec)
    //查看日志
    mysql> show master status;
    +----------------+----------+--------------+------------------+-------------------+
    | File           | Position | Binlog_Do_DB | Binlog_Ignore_DB | Executed_Gtid_Set |
    +----------------+----------+--------------+------------------+-------------------+
    | mysql52.000001 |      156 |              |                  |                   |
    +----------------+----------+--------------+------------------+-------------------+
    1 row in set (0.00 sec)
    //建库、
    mysql> create database gamedb;
    Query OK, 1 row affected (0.07 sec)
    //建表
    mysql> create table gamedb.t1(name char(10),class char(3));
    Query OK, 0 rows affected (0.55 sec)
    //插入记录
    mysql> insert into gamedb.t1 values ("yaya","nsd");
    Query OK, 1 row affected (0.08 sec)
    mysql> insert into gamedb.t1 values ("yaya","nsd");
    Query OK, 1 row affected (0.04 sec)
    mysql> insert into gamedb.t1 values ("yaya","nsd");
    Query OK, 1 row affected (0.08 sec)
    //查看表记录
    mysql> select  * from gamedb.t1;
    +------+-------+
    | name | class |
    +------+-------+
    | yaya | nsd   |
    | yaya | nsd   |
    | yaya | nsd   |
    +------+-------+
    3 rows in set (0.00 sec)
    mysql> exit
    //把日志文件拷贝给恢复数据的服务器,比如 mysql50
    [root@mysql52 ~]# scp  /mylog/mysql52.000001 root@192.168.88.50:/root/
    The authenticity of host '192.168.88.50 (192.168.88.50)' can't be established.
    ECDSA key fingerprint is SHA256:t7J3okFd0o+9zTmFCIetvDl6mxGCmc43VoD6C65zico.
    Are you sure you want to continue connecting (yes/no/[fingerprint])? Yes 同意
    Warning: Permanently added '192.168.88.50' (ECDSA) to the list of known hosts.
    root@192.168.88.50's password:  mysql50的密码
    mysql52.000001                                                              100% 1410     1.6MB/s   00:00    
    [root@mysql52 ~]#

2)在MySQL50 使用日志恢复数据

    //查看日志
    [root@mysql50 ~]# ls /root/mysql52.000001 
    /root/mysql52.000001
    //执行日志恢复数据
    [root@mysql50 ~]# mysqlbinlog /root/mysql52.000001 | mysql -uroot -pNSD2023...a
    mysql: [Warning] Using a password on the command line interface can be insecure.
    //连接服务查看数据
    [root@mysql50 ~]# mysql -uroot -pNSD2023...a -e 'select * from gamedb.t1'
    mysql: [Warning] Using a password on the command line interface can be insecure.
    +------+-------+
    | name | class |
    +------+-------+
    | yaya | nsd   |
    | yaya | nsd   |
    | yaya | nsd   |
    +------+-------+
    [root@mysql50 ~]#
相关推荐
Elastic 中国社区官方博客4 分钟前
设计新的 Kibana 仪表板布局以支持可折叠部分等
大数据·数据库·elasticsearch·搜索引擎·信息可视化·全文检索·kibana
阿俊仔(摸鱼版)5 分钟前
Python 常用运维模块之Shutil 模块
linux·服务器·python·自动化·云服务器
zhangxueyi11 分钟前
如何理解Linux的根目录?与widows系统盘有何区别?
linux·服务器·php
可涵不会debug11 分钟前
C语言文件操作:标准库与系统调用实践
linux·服务器·c语言·开发语言·c++
ghx_echo14 分钟前
linux系统下的磁盘扩容
linux·运维·服务器
深蓝海拓27 分钟前
Pyside6(PyQT5)中的QTableView与QSqlQueryModel、QSqlTableModel的联合使用
数据库·python·qt·pyqt
幻想编织者1 小时前
Ubuntu实时核编译安装与NVIDIA驱动安装教程(ubuntu 22.04,20.04)
linux·服务器·ubuntu·nvidia
利刃大大2 小时前
【Linux入门】2w字详解yum、vim、gcc/g++、gdb、makefile以及进度条小程序
linux·c语言·vim·makefile·gdb·gcc
C嘎嘎嵌入式开发2 小时前
什么是僵尸进程
服务器·数据库·c++
Yeats_Liao4 小时前
Navicat 导出表结构后运行查询失败ERROR 1064 (42000): You have an error in your SQL syntax;
数据库·sql