mysqldump的备份与恢复

MySQL(05)

备份策略:
    完全+差异+binlog(时间点还原)
    完全+增量+binlog

    备份,多久一次?
        数据变化量;
        可用的备份存储空间;


    mysqldump:
        逻辑备份、完全备份、部分备份;
        二次封装工具:
            mydumper
            phpMyAdmin

                    Usage: 
            mysqldump [OPTIONS] database [tables]
            OR     mysqldump [OPTIONS] --databases [OPTIONS] DB1 [DB2 DB3...]
            OR     mysqldump [OPTIONS] --all-databases [OPTIONS]

        MyISAM存储引擎:支持温备,备份时要锁定表;
            -x, --lock-all-tables:锁定所有库的所有表,读锁;
            -l, --lock-tables:锁定指定库所有表;

        InnoDB存储引擎:支持温备和热备;
            --single-transaction:创建一个事务,基于此快照执行备份;

        其它选项:
            -R, --routines:存储过程和存储函数;
            --triggers 
            -E, --events      

             --master-data[=#]
                1:记录为CHANGE MASTER TO语句,此语句不被注释;
                2:记录为CHANGE MASTER TO语句,此语句被注释;

            --flush-logs:锁定表完成后,即进行日志刷新操作;

    作业:备份脚本

mysqldump备份恢复示例

从lftp上mget一个数据库脚本hellodb.sql,导入到数据库中,删除导入数据库的脚本,如何自己备份。

mysqldump的备份与恢复

目前没有create databases语句,因为我们备份时直接指明了hellodb,这表式的意思是备份hellodb的所有表,而不是备份hellodb数据库的。

如果要备份数据库,要使用下面这条语句

mysqldump的备份与恢复

less hellodb.sql.2 查看一下

mysqldump的备份与恢复

这里就有create databases语句,说明整个数据库被备份下来了 –databses可以备份多个库,这里只指明了hellodb一个库

如果想备份所有库,则使用下面这条语句

mysqldump的备份与恢复

注意:数据太大的不适用mysqldump来备份 如果我们只备份一个库,这个库里面的所有表都是InnoDB存储引擎的话,可以使用热备,–single-transaction。MyISAM存储引擎的话,只能支持温备了。

备份时,备份策略:完全+增量+binlog,假如现在做一次完全备份,下次还没增量数据库就挂了,所有只能用完全+binlog来恢复,完全备份那一个,数据恢复回来了,binlog从哪一刻开始放,binlog是各种写语句,应该从备份那一刻之后的内容,把备份开始之后所发生的所有修改语句从放一遍。 如何知道什么时候开始备份:自动备份那一刻必须要记录下来,binlog正在处在哪个文件哪个privi,

例如

mysqldump的备份与恢复

这时候会报错,因为服务器上没启用bin-log,这时需要修改my.cnf配置文件,启动二进制方式

mysqldump的备份与恢复

mysqldump的备份与恢复

这时候就能成功备份了。

注意:将来备份不要去覆盖上一次备份,备份文件例如helldb。sql-20140101

这时候备份文件就多了一条语句

mysqldump的备份与恢复

意思是二进制文件处在master-log.0000001,位置是245,所以下次重放时就基于这个位置进行重放。

如何记录备份那一刻,二进制文件记录位置

备份文件要异地另存,可以写脚本进行自动化进行。备份文件要保留时间戳。

先连入mysql服务器,做一些修改操作

mysqldump的备份与恢复

mysqldump的备份与恢复

这种修改结果通过刚才的备份恢复不行,假如数据库删除,通过备份恢复不过来。这时候需要借助二进制文件进行。

mysqldump的备份与恢复

现在恢复

第一准备好备份,第二准备好二进制日志。

二进制文件都在/var/log/mysql下

mysqldump的备份与恢复

这里上次备份就只有一个二进制文件,从第一个位置开始的

使用mysqlbinlog命令

mysqldump的备份与恢复

这里会有一个问题,最后一个drop database hellodb,刚放上来,又删除掉了,不要读这个语句。

mysqldump的备份与恢复

从这里开始定义

mysqldump的备份与恢复

这时,drop database hellodb这台语句就不会出现了。

把截取后的二进制文件内容保存在一个脚本中

[root@ zhoushuang2  ~]# mysqlbinlog –stop-position=785  /var/lib/mysql/master-log.000001 > /tmp/mylog.sql

注意:这些都是脚本,通过读进行装载

第二个:hellodb.sql.2这个文件,先放到tmp下

[root@ zhoushuang2  ~]# cp hellodb.sql.2 /tmp/hellodb.sql

基于lvm2的备份:

    前提:数据目录位于逻辑卷,包含了数据文件和事务日志;

    (1) 请求锁定所有表;
        mysql> FLUSH TABLES WITH READ LOCK;

    (2) 记录二进制文件事件位置;
        mysql> FLUSH LOGS;
        mysql> SHOW MASTER STATUS;

        mysql  -e  'SHOW MASTER STATUS;' >> /PATH/TO/SOME_POS_FILE

    (3) 创建快照卷
        lvcreate  -L # -s -p r - SNAM-NAME /dev/VG-NAME/LV-NAME 

    (4) 释放锁
        mysql> UNLOCK TABLES

    (5) 挂载快照卷,并执行备份,备份完成后删除快照卷;

    (6) 周期性备份二进制日志;

接下来连接到mysql上开始恢复

1、先把二进制功能给关掉

mysqldump的备份与恢复

2、进行恢复

mysqldump的备份与恢复

这时恢复的是初始数据,后面改的没有

mysqldump的备份与恢复

再次执行操作

mysqldump的备份与恢复

再次执行发现数据都恢复了

mysqldump的备份与恢复

再把二进制功能开启

mysqldump的备份与恢复

这就是完整的备份和恢复过程

每次备份完,给自己发一封邮件

原创文章,作者:15152188070,如若转载,请注明出处:http://www.178linux.com/60155

(0)
1515218807015152188070
上一篇 2016-11-20 17:05
下一篇 2016-11-20 17:55

相关推荐

  • 计算机基础知识(第一天)

    一、计算机的硬件组成         冯诺依曼体系结构:             CPU、存储器、输入设备、输出设备       &nbsp…

    Linux干货 2016-07-26
  • linux发行版的基础目录名称命名法则及功用规定。

    Linux文件系统:         Linux:glibc标准C库                  &nb…

    Linux干货 2016-10-30
  • 系统基础之文件管理工具

    系统基础之文件管理工具   linux的重要哲学思想之一,一切皆文件.那作为系统管理员,就要求对文件的操作管理特别熟悉.那么下面介绍的一个工具可以帮助到大家,更有效,快捷的完成对文件的处理.下面让我们来认识以下的工具. 文本工具: 文件内容:   cat: 复制标准输入到标准输出     选项:   &nbs…

    Linux干货 2016-08-07
  • 文本处理工具

    文本处理工具 一、文本处理命令less,cat,more,sort 1.less  less :一页一页地查看文件或STDIN 输出  查看时有用的命令包括:   /文本  搜索 文本   n/N 个 跳到下一个 or  上一个匹配   less 命令是man…

    系统运维 2016-08-08
  • VIM编辑器入门

    VIM简介 VIM是一个类似于Vi的著名的功能强大、高度可定制的文本编辑器,在Vi的基础上改进和增加了很多特性。VIM是纯粹的自由软件。 VIM的使用 在介绍基本使用前,先了解下VIM的基本模式 基本模式可分为三种:命令模式、输入模式、末行模式 命令模式:Vim启动后的默认模式,通过输入指令完成对应的编辑操作。输入模式和末行模式从命令模式进入&nb…

    Linux干货 2016-04-05
  • LVS中nat和dr的原理与用法简述

      LVS中nat和dr的原理与用法简述 lvs-nat:   多目标IP的DNAT,通过将请求报文中的目标地址和目标端口修改为某挑出的RS的RIP和PORT实现转发; (1)RIP和DIP必须在同一个IP网络,且应该使用私网地址;RS的网关要指向DIP; (2)请求报文和响应报文都必须经由Director转发;Director…

    Linux干货 2016-10-30