MySQL多线程备份工具mydumper

一、Mydumper介绍

Mydumper是一个针对MySQL和Drizzle的高性能多线程备份和恢复工具。开发人员主要来自MySQL,Facebook,SkySQL公司。目前已经在一些线上使用了Mydumper。

Mydumper主要特性:

  • 轻量级C语言写的
  • 执行速度比mysqldump快10倍
  • 事务性和非事务性表一致的快照(适用于0.2.2以上版本)
  • 快速的文件压缩
  • 支持导出binlog
  • 多线程恢复(适用于0.2.1以上版本)
  • 以守护进程的工作方式,定时快照和连续二进制日志(适用于0.5.0以上版本)
  • 开源 (GNU GPLv3)

二、Mydumper安装

# yum install glib2-devel mysql-devel zlib-devel pcre-devel
# wget https://launchpadlibrarian.net/185032423/mydumper-0.6.2.tar.gz
# tar zxvf mydumper-0.6.2.tar.gz
# cd mydumper-0.6.2
# cmake .
# make
# make install

三、mysqldumper及myloader参数介绍

1、mydumper参数介绍:

-B, --database 需要备份的库
-T, --tables-list 需要备份的表,用,分隔
-o, --outputdir 输出目录
-s, --statement-size Attempted size of INSERT statement in bytes, default 1000000
-r, --rows 试图分裂成很多行块表
-c, --compress 压缩输出文件
-e, --build-empty-files 即使表没有数据,还是产生一个空文件
-x, --regex 支持正则表达式
-i, --ignore-engines 忽略的存储引擎,用,分隔
-m, --no-schemas 不导出表结构
-k, --no-locks 不执行临时共享读锁 警告:这将导致不一致的备份
-l, --long-query-guard 长查询,默认60s
--kill-long-queries kill掉长时间执行的查询(instead of aborting)
-b, --binlogs 导出binlog
-D, --daemon 启用守护进程模式
-I, --snapshot-interval dump快照间隔时间,默认60s,需要在daemon模式下
-L, --logfile 日志文件
-h, --host
-u, --user
-p, --password
-P, --port
-S, --socket
-t, --threads 使用的线程数,默认4
-C, --compress-protocol 在mysql连接上使用压缩
-V, --version
-v, --verbose 更多输出, 0 = silent, 1 = errors, 2 = warnings, 3 = info, default 2

2、myloader参数介绍:

-d, --directory 导入备份目录
-q, --queries-per-transaction 每次执行的查询数量, 默认1000
-o, --overwrite-tables 如果表存在删除表
-B, --database 需要还原的库
-e, --enable-binlog 启用二进制恢复数据
-h, --host
-u, --user
-p, --password
-P, --port
-S, --socket
-t, --threads 使用的线程数量,默认4
-C, --compress-protocol 连接上使用压缩
-V, --version
-v, --verbose 更多输出, 0 = silent, 1 = errors, 2 = warnings, 3 = info, default 22

3、mydumper输出文件:

  • metadata:元数据 记录备份开始和结束时间,以及binlog日志文件位置。
  • table data:每个表一个文件
  • table schemas:表结构文件
  • binary logs: 启用–binlogs选项后,二进制文件存放在binlog_snapshot目录下
  • daemon mode:在这个模式下,有五个目录0,1,binlogs,binlog_snapshot,last_dump。
    备份目录是0和1,间隔备份,如果mydumper因某种原因失败而仍然有一个好的快照,当快照完成后,last_dump指向该备份。

四、mydumper用例

# mydumper -B 361way -o /opt/mysqlbak -b
# ls
binlog_snapshot metadata 361way.my_area-schema.sql 361way.my_area.sql
# cat metadata
Started dump at: 2013-09-08 11:40:21
SHOW MASTER STATUS:
Log: mysqld-bin.000001
Pos: 191363
Finished dump at: 2013-09-08 11:40:22
# mydumper -B 361way -o /opt/mysqlbak -b -D --snapshot-interval=30
# myloader -d /opt/mysqlbak/last_dump -o -B 361way //还原

发表回复

您的电子邮箱地址不会被公开。 必填项已用*标注