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
下一篇 2016-11-20

相关推荐

  • 第三周作业

    1、列出当前系统上所有已经登录的用户的用户名,注意:同一个用户登录多次,则只显示一次即可。 [root@localhost ~]# who user1    tty1         2016-12-27&nb…

    Linux干货 2016-12-28
  • 第六周作业

    第六周作业 1、复制/etc/rc.d/rc.sysinit文件至/tmp目录,将/tmp/rc.sysinit文件中的以至少一个空白字符开头的行的行首加#; cp /etc/rc.d/rc.sysinit /tmp vim /tmp/rc.sysinit :进入末行模式 % s/^[[:space:]]/#&…

    Linux干货 2016-10-09
  • Vim编辑工具用法的总结

    描述:    Vim是一款强大的命令行界面的文本编辑器,是vi的高级版本,先说下学习它的原因:  1,所有的UNIX Like 系统都会内置vi文本编辑器,其他的文本编辑器则不一定会存在;  2,很多软件的编辑接口都会主动调用vi  3,vim具有程序编辑的能力,可以主动以字体颜色辨别语法的正确性,方便程序设…

    Linux干货 2016-08-11
  • 马哥教育网络班19期+第九周课程练习

    1、写一个脚本,判断当前系统上所有用户的shell是否为可登录shell(即用户的shell不是/sbin/nologin),分别这两类用户的个数,通过字符串比较来实现。 #!/bin/bash for user_shell in `awk -F: '{print $7}'&nbsp…

    Linux干货 2016-07-01
  • mysql基础

      mysql基础 数据模型: 数据模型:层次模型、网状模型、关系模型、…… 关系模型: 二维关系:表     行:row, entity     列:colume, attribution 索引:数据结构,辅助完成数据查找;  &nbsp…

    Linux干货 2016-11-01
  • ​redis cluster 安装指南

    公司的很多项目在使用redis主从。由于coder的各种毁灭性操作,迫切需要一个能带故障恢复的架构。因此新版的cluster,开始了测试。 一、Cluster 理论基础 Cluster介绍 Redis集群是一个提供在多个Redis间节点间共享数据的程序集。 Redis集群并不支持处理多个keys的命令,因为这需要在不同的节点间移动数据,从而达不到像Redis…

    Linux干货 2016-02-14