美文网首页
MySQL 逻辑备份 mysqldump

MySQL 逻辑备份 mysqldump

作者: leivers | 来源:发表于2019-02-25 18:48 被阅读0次

    1 特点
    自动记录position位置。

    show master  status\G;
    

    2 可用性,一致性
    锁表机制

    用法

    mysqldump  -h 服务器  -u用户名  -p密码   数据库名  > 备份文件.sql
    
    /*查看帮助*/
    mysqldump --help
    

    日常用法
    备份所有库

    // 先配置用户名和密码
    shell> vi ~/.mysql_user
    [mysqldump]
    user=root
    password=123
    
    shell> mysqldump --defaults-file=~/.mysql_user -h172.16.153.10 --all-databases > `date +%FT%H_%M_%S`dump_all.sql
    # 不包含 INFORMATION_SCHEMA,performance_schema,sys
    

    备份指定的多个库

    // 为了考虑篇幅,请自行添加指定用户名密码参数和指定服务器的参数
    // --defaults-file=~/.mysql_user -hip
    shell> mysqldump --databases db1 db2 db3 > `date +%FT%H_%M_%S`dump_all.sql
    
    

    备份指定库的指定几个表

    shell> mysqldump db1 t1 t3 t7 > dump.sql
    

    备份时不锁表

    备份时希望转储和刷新日志到恰好在同一时刻发生,适用于 InnoDB 引擎

    shell> mysqldump  --all-databases --single-transaction --flush-logs > `date +%FT%H_%M_%S`dump_all.sql
    

    --flush-logs 在开始备份数据之前刷新MySQL服务器日志文件。
    此选项需要 RELOAD权限。如果将此选项与选项结合使用 --all-databases,则会为每个转储的数据库刷新日志。会锁表。
    --single-transaction 是针对 InnoDB 引擎的表,不锁表,也称热备。

    恢复

    shell> mysql < dump.sql
    

    或者,在mysql中,使用 source命令:

    mysql> source dump.sql
    

    如果文件是不包含CREATE DATABASEUSE语句的单数据库转储 ,请首先创建数据库(如有必要):

    shell> mysqladmin create db1
    

    然后在加载转储文件时指定数据库名称:

    shell> mysql db1 < dump.sq1
    

    或者,在mysql中创建数据库,将其选为默认数据库,然后加载转储文件:

    mysql> CREATE DATABASE IF NOT EXISTS db1;
    mysql> USE db1;
    mysql>source dump.sql
    

    Example

    shell> mysql --defaults-file=~/.mysql_user < /backup/2016-12-08-04-mysql-all.sql
    

    MySQL 物理备份: Innobackupex 和 xtrabackup(热备)

    Percona XtraBackup是一款基于MySQL的热备份的开源实用程序,它可以备份5.1到5.7版本上InnoDB,XtraDB,MyISAM存储引擎的表, Xtrabackup有两个主要的工具:xtrabackup、innobackupex 。

    原来的版本

    (1)xtrabackup 只能备份InnoDB和XtraDB两种数据引擎的数据表,而不能备份MyISAM数据表

    (2)innobackupex 则封装了 xtrabackup,是一个脚本封装,所以能同时备份处理innodb和myisam,但在处理myisam时需要加一个读锁。

    新版本的变化

    如果你安装了2.3之前版本的xtrabackup,那么在备份的过程中,你可能会用到两个常用的备份工具。

    安装2.3版本之前的XtraBackup后,我们会得到两个主要的备份工具:

    • xtrabackup
    • innobackupex

    xtrabackup是一个C程序。

    innobackupex是一个perl脚本,它对xtrabackup这个C程序进行了封装,在备份innodb表时,此脚本会调用xtrabackup这个C程序。

    如果使用xtrabackup这个C程序进行备份,则只能备份innodb和xtradb的表,不能备份myisam表。

    如果使用innobackupex进行备份,则可以备份innodb或xtradb的表,同时也能够备份myisam表。

    所以,一般在使用XtraBackup备份工具进行数据备份时,通常会选择使用innobackupex命令进行备份。

    那么问题来了。

    xtrabackup是一个C程序,innobackupex是一个perl脚本,当它们作为两个进程运行时,总是没有特别完美的方式让它们进行通讯,当它们作为一个整体进行工作时就不太尽如人意,如此情况,就导致了一些bug的出现,于是,官方决定使用C重写innobackupex,将它与xtrabackup这个C程序完美的整合在一起。这个想法在2.3版本的XtraBackup中实现。

    官方手册解释

    xtrabackup
    一个已编译的C二进制文件,它提供了使用MyISAM,InnoDB和XtraDB表备份整个MySQL数据库实例的功能

    而我们安装的就是2.4版本,此时,innobackupex的功能已经完全整合到了xtrabackup中,innobackupex不再是perl脚本了,但是,为了兼容之前用户的使用习惯,官方保留了innobackupex,它作为一个软连接,指向了xtrabackup,也就是说,在2.4版本中,不管我们使用innobackupex命令,还是xtrabackup命令,其实使用的都是这个xtrabackupC程序。虽然在实现上有所不同,但是在工作原理上,与之前的版本并没有什么不同。

    下面我们用新的命令xtrabachup使用。

    首先我们先来简单的了解一下xtrabackup 是怎么工作的。xtrabackup 基于innodb的crash-recovery(实例恢复)功能,先copy innodb的物理文件(这个时候数据的一致性是无法满足的),然后进行基于redo log进行恢复,达到数据的一致性。

    全备

    下面的命令均假设没有在 my.cnf 中配置任何关于 xtrabackup 的选项
    要执行备份需要指定 备份数据放置的位置,就是目录,假如目录不存在,则会自动创建;==注意这个目录不会被递归创建,仅仅会创建最后一级目录;==假如存在,就会直接开始备份,并且不会覆盖原来的数据。

    1 开始备份

    shell> xtrabackup --backup --user=root --password='123'  --target-dir=/backups/
    
    # 备份完成后,可以看到备份时的LSN号,当下次进行增量备份时,xtrabackup就只备份大于此号的page即可。
    

    查看备份文件

    [root@mysql-master ~]# ls -lh /data/backups/
    总用量 13M
    -rw-r----- 1 root root  487 8月  18 09:44 backup-my.cnf
    -rw-r----- 1 root root  293 8月  18 09:44 ib_buffer_pool
    -rw-r----- 1 root root  12M 8月  18 09:44 ibdata1
    drwxr-x--- 2 root root 4.0K 8月  18 09:44 mysql
    drwxr-x--- 2 root root   88 8月  18 09:44 one_db
    drwxr-x--- 2 root root 8.0K 8月  18 09:44 performance_schema
    drwxr-x--- 2 root root   58 8月  18 09:44 shark_db
    drwxr-x--- 2 root root 8.0K 8月  18 09:44 sys
    -rw-r----- 1 root root  115 8月  18 09:44 xtrabackup_checkpoints
    -rw-r----- 1 root root  446 8月  18 09:44 xtrabackup_info
    -rw-r----- 1 root root 2.5K 8月  18 09:44 xtrabackup_logfile
    

    进入目录后,可以看到一些目录,这些目录与我们数据库的名称相同,没错,这些就是各个数据库的数据文件备份目录。
    还有一个innodb的共享表空间文件,ibdata1,注意,如果想要使用xtrabackup备份众多数据库中的某一个,那么必须保证在创建这个数据库时,已经开启了innodb_file_per_table参数,否则将无法单独备份数据库服务器中的某一个数据库。
    除了刚才描述的这些数据文件,xtrabackup还为我们生成了一些文件,我们来看看这些文件都有什么用(不同版本的xtrabackup生成的文件可能不同)。

    backup-my.cnf
    此文件中包含了my.cnf中的一些设置信息,但是,并不是my.cnf中的所有信息都会包含在此文件中,此文件中只包含了备份时需要的信息。
    xtrabackup_binlog_info
    需要开启二进制日志
    此文件中记录了备份开始时二进制日志文件的"位置(position)"
    xtrabackup_checkpoints
    此文件中记录此次备份属于那种类型的备份,是全量还是增量,备份时起始的LSN号码,结束的LSN号码等信息。
    xtrabackup_info
    本次备份的概要信息,此文件中的信息还是比较全面的。
    xtrabackup_logfile
    记录了备份过程中的日志,在对数据进行prepare时需要通过日志将数据还原成一致的可用的数据。

    准备恢复的数据

    使用 xtrabackup --backup 选项进行备份后,并不能直接使用,首先需要准备它以便还原它。
    如果您尝试使用这些数据文件启动InnoDB,它将检测损坏并自行崩溃,以防止您在损坏的数据上运行。
    因为备份出的数据是不一致的,我们需要将同时备份出的事务日志应用到备份中,才能得到一份完整、一致、可用的数据,xtrabackup称这一步操作为prepare,直译过来就是"准备"。
    xtrabackup --prepare 步骤使文件在一个时刻完全一致

    shell> xtrabackup --prepare --target-dir=/data/backups/
    

    如果你要备份的数据量巨大,那么备份时长会变长,期间备份的事务日志容量有可能会很大。那么,我们可以使用--use-memory选项,加速准备工作的完成,在不指定内存大小的情况下,准备工作默认会占用100MB的内存,如果服务器有一定的空闲内存,那么我们可以让xtrabackup使用指定大小的内存完成准备工作,以提升准备工作完成的速度,示例语句如下。

    shell> xtrabackup --prepare --use-memory=512M --target-dir=/backups/
    

    ==准备备份时不建议中断xtrabackup进程,因为这可能会导致数据文件损坏,备份将无法使用。如果准备过程中断,则无法保证备份有效性。==

    准备备份数据完成后,应该会看到如下信息。

    InnoDB: Starting shutdown...
    InnoDB: Shutdown completed; log sequence number 13596200
    180818 10:09:19 completed OK!
    

    恢复

    xtrabackup 在执行copyback时会读取数据库的my.cnf中的配置,但是如果my.cnf中没有配置datadir,那么--datadir选项必须存在,而且,datadir目录必须为空目录,其中不能存在数据,否则在执行上述命令时会报错,--copy-back选项对应的目录就是我们准备好的可用数据的目录。
    为了能够正常的恢复数据,我们先确定数据库服务已经停止了,而且对应的数据目录中不存在数据,然后进行数据还原工作,删除数据目录中的文件与日志。

    停止数据库的服务
    清理环境
    修改权限
    启动数据库

    shell> systemctl stop mysqld.service
    
    shell> rm -rf /var/lib/mysql/*
    
    shell> xtrabackup --copy-back --datadir=/var/lib/mysql --target-dir=/data/backups/
    
    # 下面为完成后的输出结果
    180818 10:59:25 [01]        ...done
    180818 10:59:25 completed OK!
    shell> chown  mysql.mysql -R /var/lib/mysql
    

    或者使用 rsync 命令

    shell> rsync -avrP /data/backup/ /var/lib/mysql/
    shell> chown  mysql.mysql -R /var/lib/mysql
    

    启动数据库

    shell> systemctl start mysqld.service
    

    innobackuper 命令实现

    shell> innobackupex --defaults-file=/etc/my.cnf --host=192.168.1.146 --user=root --password=123123 /backup
    
    shell> nnobackupex --apply-log --use-memory=4G /backup/2018-08-17_15-53-11
    
    shell> systemctl stop mysqld.service
    
    shell> rm -rf /var/lib/mysql/*
    
    shell> innobackupex --datadir=/var/lib/mysql --copy-back 2018-08-17_15-53-11
    
    shell> chown  mysql.mysql -R /var/lib/mysql
    
    shell> systemctl start mysqld.service
    
    

    全量备份思路总结

    执行备份命令

    指定 数据库的用户名和密码
    指定 备份目录,注意只可以自动创建最后一级的目录

    准备备份的数据

    就是指: --prepare 参数, 保证数据的统一且完整性

    停服务,并且把 mysql 的数据目录下的所有文件和文件夹清除。

    /var/lib/mysql/ 此目录必须是空的

    恢复数据

    本质上就是拷贝备份的文件到指定的 mysql 数据目录下

    修改 mysql 数据目录的属主和属组为 MySQL 服务器进程启动的用户,默认是 mysql
    启动服务

    相关文章

      网友评论

          本文标题:MySQL 逻辑备份 mysqldump

          本文链接:https://www.haomeiwen.com/subject/kvngyqtx.html