数据库的备份与恢复 mysqldump+binlog方式

本文涉及的产品
云数据库 RDS MySQL Serverless,0.5-2RCU 50GB
云数据库 RDS MySQL Serverless,价值2615元额度,1个月
简介:

实验说明:

(1)mysqldump:逻辑备份工具,适用于所有存储引擎,可用于温备,能实现完全备份,部分备份;对InnoDB存储引擎支持热备;

        binlog:二进制日志

        二进制日志也叫作变更日志,主要用于记录修改数据或有可能引起数据改变的mysql语句,并且记录了语句发生时间、执行时长、操作的数据等等。所以说通过二进制日志可以查询mysql数据库中进行了哪些变化。一般大小体积上限为1G


(2)本次实验使用备份方式:完全备份+增量备份。

(3)musqldump命令的语法格式

mysqldump [OPTIONS] database [tables]备份单个库,或库指定的一个或多个表

mysqldump [OPTIONS] --databases [OPTIONS] DB1 [DB2 DB3...]备份一个或多个库

mysqldump [OPTIONS] --all-databases [OPTIONS]备份所有库

    其他选项

        -x, --lock-all-tables:锁定所有表

        -l, --lock-tables:锁定备份的表

        --single-transaction启动一个大的单一事务实现备份

        -C, --compress压缩传输

        -E, --events备份指定库的事件调度器

        -R, --routines备份存储过程和存储函数

        --triggers备份触发器

        --master-data={0|1|2}

            0不记录

            1记录CHANGE MASTER TO语句;此语句未被注释

            2记录为注释语句

            -F,--flush-logs:锁定表之后执行flush logs命令


1、安装数据库

    centos6:  yum  install mysql

    centos7:  yum  install mariadb

2、开启二进制日志

      在配置文件修改

        vim  /etc/my.cnf

        [mysqld]   

         log-bin=bin-log  添加改行,采用相对路径,真实存储路径为/var/lib/mysql/下

        481da544a250f579ff0bf17d31805e62.png

3、启动服务

        systemctl start mariadb

        ls /var/lib/mysql

        会看到bin-log.000001 文件

        次重启mysql服务或运行mysql> flush logs;都会生成一个新的二进制日志文件,这些日志文件的number会不断地递增。除了生成上述的文件外还会生成一个为filename.index(bin-log.index)的文件。这个文件中存储所有二进制日志文件的清单又称为二进制文件的索引。

4、登入数据库并创建需要备份的数据库

        mysql -uroot -p

   (1)建立数据库

        create database mariadb  

   (2)建立表

        use mariadb

        create table table1(id int ,name char(20));

        show tables;查看是否创建表成功

   (3)插入数据

           insert into table1  values (1,'one');

            insert into table1  values (2,'two');

            insert into table1  values (3,'three');

           insert into table1  values (4,'for'); 

            查看是否插入数据到表中

            select * from table1

            a508425fbd5bd6db709a162fc9076849.png

5、进行完整备份

    (1)创建要备份的目录

            mkdir /backup

      (2)备份

       mysqldump --databases mariadb --lock-all-tables --lock-tables  --flush-log --master-data=2 >/backup/`date +%F-%T`-all.sql    

      (3) 查看是否备份成功

            ls  /backup

            a772f5c235e81b9afc233ee6408673af.png

6、向表中插入数据,进行增量备份

     (1)查看 当前使用的二进制文件及所处位置

            show master status; 

        0b4f387dad873c41328ae04f7278ff24.png

                     

    (2)插入数据

        insert into table1 values (5,five);

        cb96f34964b9e514c6e6dcfd22093ee8.png

7、增量备份

    (1)查看二进制日志

        mysqlbinlog /var/lib/mysql/bin-log.000002

        选择备份的位置

        b11dc54a36c9bf09e8919c5c0ed3c7bf.png

    插入数据前,即完全备份的位置在245

    插入数据后,位置在418

   说明:整个事务一般以BEGIN开头到COMMIT结束,注意一定要看清,很容易出错。

(2)进行增量备份

        mysqlbinlog --start-position=245 --stop-position=418 /var/lib/mysql/bin-log.000002 > /backup/`date +%F-%T`-add.sql

    ls /backup

    894853055f5881c40e350a7f8b198851.png

 8、继续插入数据,在没备份的情况下删除数据库,模拟误操作

     inset into table1 values (6,'six');

     drop  database mariadb;

    1273c7d82492f36108936e4db6891422.png

9、不要慌张

10、备份未备份的操作

    由于最后我们没有备份就删除了数据库,所以我们首先需要保护最后的二进制日志,查看删除操作之前的position值

    mysqlbinlog /var/lib/mysql/bin-log.000002

    9b5a47b7d60248f25761852c41001eef.png

   所以备份位置从结束位置在643

     mysqlbinlog  --start-position=445  --stop-position=643 /var/lib/mysql/bin-log.000002 > /backup/`date +%F-%T`-add.sql

    一定不要备份误删除的位置,不然恢复后,又被删除,就恢复不了。

11、恢复数据库

    mysql < /backup/2017-11-16-14\:24\:31-all.sql 先恢复完全备份

    mysql < /backup/2017-11-16-14\:53\:33-add.sql  恢复第一个增量备份

    mysql < /backup/2017-11-16-15\:13\:23-add.sql  恢复最后备份

12、登录数据库查看

        5abbfad9f688805b36801aa76a584fc1.png


        d1edfed9c9d45d1b802f3d53a91c8058.png

   数据恢复成功。数据位置为完全正确。



本文转自 hawapple 51CTO博客,原文链接:http://blog.51cto.com/guanm/1982422

相关实践学习
基于CentOS快速搭建LAMP环境
本教程介绍如何搭建LAMP环境,其中LAMP分别代表Linux、Apache、MySQL和PHP。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
3天前
|
SQL 存储 监控
关系型数据库做好备份
关系型数据库做好备份
19 6
|
2月前
|
SQL 关系型数据库 MySQL
【MySQL技术专题】「问题实战系列」深入探索和分析MySQL数据库的数据备份和恢复实战开发指南(备份+恢复篇)(二)
【MySQL技术专题】「问题实战系列」深入探索和分析MySQL数据库的数据备份和恢复实战开发指南(备份+恢复篇)
58 1
|
2天前
|
关系型数据库 MySQL 数据库连接
用Navicat备份Mysql演示系统数据库的时候出:Too Many Connections
用Navicat备份Mysql演示系统数据库的时候出:Too Many Connections
|
6天前
|
存储 SQL Oracle
关系型数据库的备份和恢复
关系型数据库的备份和恢复是确保数据安全性和完整性的重要手段。需要根据具体的需求和场景选择合适的备份和恢复方法,并遵循相关的注意事项来确保备份和恢复的成功。
28 2
|
11天前
|
弹性计算 关系型数据库 MySQL
|
16天前
|
SQL 调度 数据库
【Database】Sqlserver如何定时备份数据库和定时清除
【Database】Sqlserver如何定时备份数据库和定时清除
23 2
|
1月前
|
数据库
使用Navicat Premium 12进行数据库定期自动备份(定时任务)--图文详解
使用Navicat Premium 12进行数据库定期自动备份(定时任务)--图文详解
24 0
|
1月前
|
SQL 存储 关系型数据库
mysql数据库备份与恢复
mysql数据库备份与恢复
|
1月前
|
SQL 关系型数据库 MySQL
mysql数据库备份 与恢复 win下的mysql数据备份
mysql数据库备份 与恢复 win下的mysql数据备份
16 1
|
2月前
|
SQL 关系型数据库 MySQL
【MySQL技术专题】「问题实战系列」深入探索和分析MySQL数据库的数据备份和恢复实战开发指南(备份+恢复篇)(一)
【MySQL技术专题】「问题实战系列」深入探索和分析MySQL数据库的数据备份和恢复实战开发指南(备份+恢复篇)
31 1