MySQL逻辑备份利器-mydumper

关于mydumper的简介和下载请访问:https://launchpad.net/mydumper

简言之,mydumper是多线程逻辑备份,对于表和数据量很大的情况下,建议使用mydumper提高备份效率,比mysqldumper要快很多。

我为什么要用mydumper?是基于某个需求,比如我需要把某个库下的所有按日期分表的表备份并导入到新实例?如何实现?

table_20170101
table_20170102
......
table_20171231

一共三百多张表

开始我去尝试mysqldump,看到参数:-B [table1,table2......table n] ,多么厚颜无耻的说咱支持多个指定表备份,5个以下完全接受,但是我要备份1000个表,你要让我在那列1000个吗?我始终不相信,mysqldump怎么能不支持表名模糊匹配呢?于是我就使用下面的写法:

mysqldump  -uxx -p -B xx  table_* > backup.sql

执行没有报错,惊喜,我就说嘛,怎么能不支持表的模糊匹配呢!!当我打开backup.sql文件时,膀胱都气炸了,尼玛直接备份了某个数据库下所有的表了。忽视我的模糊匹配嘛。从此对mysqldump没有好印象了,(当然也可能是我能力有限,还没有找到mysqldump的多表备份方式)。

转投mydumper,当我看到-x参数时,又是一喜!看看人家,写的多么清晰,于是开始使用:

一、mydumper安装:

# yum install glib2-devel mysql-devel zlib-devel pcre-devel
# wget http://launchpad.net/mydumper/0.9/0.9.1/+download/mydumper-0.9.1.tar.gz
# tar zxvf mydumper-0.9.1.tar.gz -C ../software/
# cmake .
# make
# make install

二、使用mydumper

1、刚用时报错:

/usr/local/bin/myloader: error while loading shared libraries: libmysqlclient.so.18: cannot open shared object file: No such file or directory

解决方法:

# locate libmysqlclient.so.18
     /usr/local/mysql/lib/libmysqlclient.so.18
     /usr/local/mysql/lib/libmysqlclient.so.18.1.0
# echo "/usr/local/mysql/lib" >> /etc/ld.so.conf
# ldconfig 

2、重要参数介绍:

-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

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 2

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指向该备份。

3、用例

# 将某个库下日表备份
mydumper -x "new_broker.broker_action_log_*"  -o /data/dbbackup/tmp/   --host=‘xxxx‘ --user=‘xxxx‘ --password=‘xxx‘ --port=‘3306‘ --logfile=‘/data/dbbackup/tmp/mydumper.log‘  --threads=6 -v 3

#将备份数据恢复到新数据库broker_biz_log中
myloader  -t 6 -v 3 --host=‘xxxx‘ --user=‘xxxx‘ --password=‘xxxx‘ --port=‘3306‘  -B broker_biz_log  --directory=‘/data/dbbackup/tmp‘ 

4、使用误区

需求1:备份多个数据库下所有表

【错误案例,有部分库导出失败】

nohup mydumper -x "(test_db.*)|(test.*)|(mysql.*)" -o /data/dbbackup/mydumper/ --host=‘192.168.1.20‘ --user=‘secret‘ --password=‘xx‘ --port=‘3306‘ --logfile=‘/data/dbbackup/mydumper/mydumper.log‘ --threads=6 -v 3 &

【正确的写法】

nohup mydumper -x "(test_db|test|mysql).*" -o /data/dbbackup/mydumper/ --host=‘192.168.1.20‘ --user=‘secret‘ --password=‘xx‘ --port=‘3306‘ --logfile=‘/data/dbbackup/mydumper/mydumper.log‘ --threads=6 -v 3 &

需求2:备份所有数据库下所有表

mydumper -o /data/dbbackup/mydumper/ --host=‘ip‘ --user=‘secret‘ --password=‘xx‘ --port=‘3306‘ --logfile=‘/data/dbbackup/mydumper/mydumper.log‘ --threads=6 -v 3

[myloader]

--将/data/dbbackup/mydumper上的所有库都恢复

【正确的写法】

nohup myloader -t 6 -v 3 -u secret -p xxx -S /tmp/mysql.sock --directory=‘/data/dbbackup/mydumper‘ &

【值得注意的是: myloader是以.为分隔符来截取库名的,所以如果本身库的名字中包含.的,那么会失败】

时间: 2024-12-15 01:40:15

MySQL逻辑备份利器-mydumper的相关文章

MySQL 逻辑备份神器

简介: Mydumper.Myloader 是一个第三方的.开源的 MySQL 逻辑备份工具. 支持多线程,比起 mysqldump 要快很多,也能解决 innobackupex 备份工具对 MyISAM 引擎备份的不便. 多线程快速逻辑备份,支持快照功能. 下载地址:https://launchpad.net/mydumper/0.9/0.9.1/+download/mydumper-0.9.1.tar.gz 一.安装 Mydumper shell > yum -y install gcc g

(4.12)mysql备份还原——mysql逻辑备份之mysqldump

关键词:mysql逻辑备份介绍,mysqldump 1.mysql逻辑备份介绍 [1.1]备份内容:数据库的结构定义语句+数据内容的插入语句,备份出来的文件可以编辑 [1.2]使用场景:数据量较少的库,比较适合100G数据量以内的 逻辑备份的特点 (1)sql语句组成的文件,可以编辑截取部分单独使用. (2)备份文件比物理文件小 (3)可以细化到表/表的内容 (4)速度慢 (5)可以跨平台恢复/迁移 2.逻辑备份工具 [1.1]mysqldump(单线程).mysqlpump(多线程,5.7以后

MySQL多线程备份工具:mydumper

MySQL多线程备份工具:mydumper http://www.orczhou.com/index.php/2011/12/how-to-split-mysqldump-file/ Mydumper是一个针对MySQL和Drizzle的高性能多线程备份和恢复工具.开发人员分别来自MySQL,Facebook,SkySQL公司.目前已经在有一些大型产品业务上测试并使用了Mydumper.分稳定版和开发版两种,目前最新稳定版是0.2.3和最新开发版是0.5.1.恢复时可使用myloader工具.

mysql逻辑备份2种方案

mysql逻辑备份方案: 针对db进行逻辑备份(由于数据量较小,正在生产环境使用). mysql_backup.sh #!/bin/bash date=`date +%F-%H-%M` mkdir /opt/backup/${date} -p usesize=`du -s /opt/mysql |cut -f 1` biaozhun=`df  /opt/ |awk 'END{print ("'$usesize'"+$3)/$2*100+0.5}'|cut -d. -f1` ip=`gr

MySQL逻辑备份mysqldump

一个用mysqldump做逻辑备份的小脚本 用于小数据量的备份,全库,按日期,按库,按表,进行分类 # date -s "2015/01/01" && bash mybackup.sh #!/bin/bash # 使用mysqldump进行逻辑备份 # 目录结构/backup/日期 # 每隔7天删除旧的备份目录 db_backup_root="/backup" today=`date +%Y%m%d` old_backup_dir=`date -d

mysql逻辑备份与还原工具mysqldump

(一)mysqldump介绍 mysqldump是MySQL自带的逻辑备份工具,类似于Oracle的expdp/impdp,mysqldump备份十分灵活,可以在以下级别对数据库进行备份: 实例下的所有数据库 某个或某几个数据库 某个数据库中的表 某个数据库中的表的某些记录 mysqldump的备份结果集有两种文件:一种是将数据转换为标准的SQL语句,另一种是按照指定的分隔符,输出为特定格式的平面文件. (二)mysqldump的用法 可以直接使用mysqldump命令查看mysqldump的用

mysql逻辑备份

逻辑备份一般用于数据迁移或者数据量很小事,逻辑备份采用的是数据导出的备份方式. 如果需要导出所有数据库,命令如下: mysqldump -uroot -p --single-transaction -A>all.sql 如果只是要导出其中的某几个数据库,则采用如下命令: mysqldump -uroot -p --single-transaction -B test1 test2>test1_test2.sql 如果要是导出的是一个库中的某几个表,可采用如下命令: mysqldump -uro

MySQL多线程备份恢复工具mydumper,myloder

mydumper是多线程备份工具,默认开启4个线程,比mysqldump的速度更快 mydumper备份时,数据和表结构是分开的,比如备份test表时,会生成test.sql文件和test.schema.sql文件. myloader导数据的时候默认不会记录二进制日志,即使你的sql_log_bin=on. 准备安装介质: 下载mydumper-0.6.2.tar.gz 下载地址:https://launchpad.net/mydumper 安装依赖包: # yum install glib2-

MySQL多线程备份工具mydumper

mydumper是一个针对MySQL和Drizzle的高性能多线程的备份和恢复工具.此工具的开发人员分别来自MySQL.Fackbook.SkySQL公司,目前已经有一些大型产品业务测试并使用了该工具.我们在恢复数据库时也可以使用myloader工具. Mydumper的主要特性包括: 一.采用了轻量级C语言写的代码. 二.相比于mysqldump,其速度快了近10倍(有待测试) 三.具有事务性和非事务性表一致的快照(应用于0.2.2+) 四.可以快速进行文件压缩(File compressio