博客
关于我
mysqldump实现数据备份及灾难恢复
阅读量:789 次
发布时间:2023-02-11

本文共 1538 字,大约阅读时间需要 5 分钟。

测试环境介绍

备份策略

备份

全备份操作

[root@mariadb ~]# mysqldump -uroot -p123456 --lock-all-tables --flush-logs --events --routines --master-data=2 --all-databases > /backup/data_dir/fulldata-`date +%F`.sql

说明:

  • --lock-all-tables:锁定数据库中的所有表,防止在备份过程中其他连接操作导致数据不一致。
  • --flush-logs:刷新二进制日志文件,使后续增量备份基于新文件。
  • --master-data=2:记录当前二进制日志文件及位置,便于增量备份。

创建增量备份

[root@mariadb ~]# cp /var/log/mysql_log/mysql-bin.000004 /backup/binlog_dir/mysql-bin.000004-increment.`date +%F`

数据修改

mysql> CREATE DATABASE mydb2;mysql> USE mydb2;mysql> CREATE TABLE tb2 (id INT, name CHAR(15));

增量备份

mysql> SHOW MASTER STATUS;

执行后滚动日志:

mysql> FLUSH LOGS;mysql> SHOW MASTER STATUS;

备份二进制日志文件:

[root@mariadb ~]# cp /var/log/mysql_log/mysql-bin.000004 /backup/binlog_dir/mysql-bin.000004-increment.`date +%F`

数据修改

mysql> INSERT INTO mydb2.tb2 (id, name) VALUES (1, 'timepoint');

灾难恢复

模拟数据丢失

mysql> DROP DATABASE myddb1;mysql> DROP DATABASE myddb2;

服务器下线

[root@mariadb ~]# /opt/lamp/mysql55/bin/mysqld_safe --skip-networking &

恢复准备

mysql> SET GLOBAL sql_log_bin=0;mysql> SHOW GLOBAL VARIABLES LIKE 'sql_log_bin';

滚动日志并恢复全备份:

[root@mariadb ~]# mysql -uroot -p123456 < /backup/data_dir/fulldata-2015-04-14.sql

增量恢复

[root@mariadb ~]# mysqlbinlog /backup/binlog_dir/mysql-bin.000004-increment.2015-04-14 > /tmp/increment.sql

时间点恢复

[root@mariadb ~]# mysqlbinlog --stop-position=321 /var/log/mysql_log/mysql-bin.000005 > /tmp/321ttim.sql

收尾

mysql> SET GLOBAL sql_log_bin=1;[root@mariadb ~]# service mysqld restart

总结

mysqldump工具适用于InnoDB存储引擎的热备备份,但对包含MyISAM表的库需要在备份前锁定表。全备份+增量备份结合使用,既实现数据备份,又支持灾难恢复。

转载地址:http://jibfk.baihongyu.com/

你可能感兴趣的文章
Mysql 数据库重置ID排序
查看>>
Mysql 数据类型一日期
查看>>
MySQL 数据类型和属性
查看>>
mysql 敲错命令 想取消怎么办?
查看>>
Mysql 整形列的字节与存储范围
查看>>
mysql 断电数据损坏,无法启动
查看>>
MySQL 日期时间类型的选择
查看>>
Mysql 时间操作(当天,昨天,7天,30天,半年,全年,季度)
查看>>
MySQL 是如何加锁的?
查看>>
MySQL 是怎样运行的 - InnoDB数据页结构
查看>>
mysql 更新子表_mysql 在update中实现子查询的方式
查看>>
MySQL 有什么优点?
查看>>
mysql 权限整理记录
查看>>
mysql 权限登录问题:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)
查看>>
MYSQL 查看最大连接数和修改最大连接数
查看>>
MySQL 查看有哪些表
查看>>
mysql 查看锁_阿里/美团/字节面试官必问的Mysql锁机制,你真的明白吗
查看>>
MySql 查询以逗号分隔的字符串的方法(正则)
查看>>
MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
查看>>
mysql 查询数据库所有表的字段信息
查看>>