目录

一、全量备份与恢复

1.全量备份

2.删掉某个数据库

3.全量恢复数据库

二、增量备份与恢复

1.查看增量是否开启,我们发现log_bin开启证明开启了

2.创建一个数据库并创建表中信息

3.插入数据

4.进行一次全量的备份

5.做完备份刷新一下数据库,重新进行写入数据

6.在数据库中增加一条新的数据,删除原来的一条数据

7.删掉其中一个数据库

三、全量、增量的数据库恢复

1.先刷新一下数据库

2.查看数据库之前的所有的数据

3.查看当前使用的数据库

4.查看之前数据的操作,确定在哪里被删除的,我们发现在926时候删除的

5.先进行一个全量恢复

6.查看数据库信息

7.我们看mydb数据发现虽然是进行了全量恢复,但是我们没恢复删除前的数据。

8.将删除数据前的数据记录设置为增量数据

9.进行增量恢复的操作

10.查看数据是否恢复

一、全量备份与恢复

1.全量备份

mysqldump -uroot -proot --databases -default-character-set=utf8mb4 > backup.sql

全量备份表和数据 postgresql mysql数据库全量备份_全量备份表和数据 postgresql

2.删掉某个数据库

drop database sys;

全量备份表和数据 postgresql mysql数据库全量备份_mysql_02

3.全量恢复数据库

mysql -uroot -proot < backup.sql;

全量备份表和数据 postgresql mysql数据库全量备份_数据库_03

二、增量备份与恢复

1.查看增量是否开启,我们发现log_bin开启证明开启了

show varibles like '%bin%';

全量备份表和数据 postgresql mysql数据库全量备份_数据库_04

2.创建一个数据库并创建表中信息

create  table stu_info(
stu_nu int primary key auto_increment,
stu_name varchar(30) not null
) auto_increment=1001;

全量备份表和数据 postgresql mysql数据库全量备份_数据库_05

3.插入数据

insert into stu_info values(null,'张三'),(null,'李四'),(null,'王五');
select * from stu_info;

全量备份表和数据 postgresql mysql数据库全量备份_数据库_06

4.进行一次全量的备份

mysqldump -uroot -proot --all-databases --default-character-set=utf8mb4 > backup1.sql

全量备份表和数据 postgresql mysql数据库全量备份_数据_07

5.做完备份刷新一下数据库,重新进行写入数据

mysqladmin -uroot -proot flush-logs

全量备份表和数据 postgresql mysql数据库全量备份_数据库_08

6.在数据库中增加一条新的数据,删除原来的一条数据

insert into stu_info values (null,'李丽');
delete from stu_info where stu_nu=1002;
select * from stu_info;

全量备份表和数据 postgresql mysql数据库全量备份_数据_09

7.删掉其中一个数据库

drop databases mydb;

全量备份表和数据 postgresql mysql数据库全量备份_mysql_10

三、全量、增量的数据库恢复

1.先刷新一下数据库

flush logs;

全量备份表和数据 postgresql mysql数据库全量备份_数据_11

2.查看数据库之前的所有的数据

show master logs;

全量备份表和数据 postgresql mysql数据库全量备份_数据_12

3.查看当前使用的数据库

show master status;

全量备份表和数据 postgresql mysql数据库全量备份_数据_13

4.查看之前数据的操作,确定在哪里被删除的,我们发现在926时候删除的

show binlog events in 'binlog.000009';

全量备份表和数据 postgresql mysql数据库全量备份_全量备份表和数据 postgresql_14

5.先进行一个全量恢复

mysql -uroot -proot < backup1.sql

全量备份表和数据 postgresql mysql数据库全量备份_全量备份表和数据 postgresql_15

6.查看数据库信息

show databases;

全量备份表和数据 postgresql mysql数据库全量备份_全量备份表和数据 postgresql_16

7.我们看mydb数据发现虽然是进行了全量恢复,但是我们没恢复删除前的数据。

select * from stu_info;

全量备份表和数据 postgresql mysql数据库全量备份_数据_17

8.将删除数据前的数据记录设置为增量数据

mysqlbinglog binlog.000009 > increment.sql

全量备份表和数据 postgresql mysql数据库全量备份_数据库_18

9.进行增量恢复的操作

mysqlbinlog -uroot -proot binlog.000009 --start-position=4 --stop-position=822 -r result.sql
mysql -uroot -proot < result.sql

全量备份表和数据 postgresql mysql数据库全量备份_数据库_19

10.查看数据是否恢复

select * from stu_info;

全量备份表和数据 postgresql mysql数据库全量备份_数据库_20