mydumper工作原理解析

1、简介

逻辑备份小钢炮--mydumper是针对MySQL的高性能多线程备份工具。该工具是由MySQL、Facebook、skysql公司的开发人员一起开发的。是由轻量级C语言开发;执行速度据说比mysqldump快10倍;支持事务和非事务表的一致性备份;还支持导出binlog;支持多线程备份;支持以守护进程的形式工作,定时备份;并且是开源的,其协议为GPLv3.

2、使用方法

点击(此处)折叠或打开

  1. root@dd:~/mydumper-0.6.2# ./mydumper --help
  2. Usage:
  3. mydumper [OPTION...] multi-threaded MySQL dumping

  4. Help Options:
  5. -?, --help Show help options
  6.  
  7. Application Options:
  8. -B, --database 需要备份的库
  9. -T, --tables-list 需要备份的表,用逗号分隔
  10. -o, --outputdir 输出文件的目录
  11. -s, --statement-size 生成插入语句的字节数, 默认 1000000,这个参数不能太小,不然会报 Row bigger than statement_size for tools.t_serverinfo
  12. -r, --rows 分裂成很多行块表
  13. -c, --compress 压缩输出文件
  14. -e, --build-empty-files 即使表没有数据,还是产生一个空文件
  15. -x, --regex 正则表达式: 'db.table'
  16. -i, --ignore-engines 忽略的存储引擎,用逗号分隔
  17. -m, --no-schemas 不导出表结构
  18. -k, --no-locks 不执行共享读锁 警告:这将导致不一致的备份
  19. -l, --long-query-guard 设置长查询时间,默认60秒,超过该时间则会报错:There are queries in PROCESSLIST running longer than 60s, aborting dump
  20. --kill-long-queries kill掉长时间执行的查询
  21. -b, --binlogs 导出binlog
  22. -D, --daemon 启用守护进程模式
  23. -I, --snapshot-interval dump快照间隔时间,默认60s,需要在daemon模式下
  24. -L, --logfile 日志文件
  25. -h, --host The host to connect to
  26. -u, --user Username with privileges to run the dump
  27. -p, --password User password
  28. -P, --port TCP/IP port to connect to
  29. -S, --socket UNIX domain socket file to use for connection
  30. -t, --threads 使用的线程数,默认4
  31. -C, --compress-protocol 在mysql连接上使用压缩协议
  32. -V, --version Show the program version and exit
  33. -v, --verbose 更多输出, 0 = silent, 1 = errors, 2 = warnings, 3 = info, default 2
3、原理解析

1)该工具在--daemo模式下支持以守护进行形式启动,默认每60s进行一次备份。间隔时间由--snapshot-interval控制。

2)首先会创建一个MySQL服务的连接

3)然后在MySQL上执行show processlist,根据参数long-query-guard和kill-long-queries决定退出或杀掉长查询;

4)根据是否有--lock-all-tables,进行锁表:LOCK TABLE tn READ或者FLUSH TABLES WITH READ LOCK;然后执行START TRANSACTION;

5)创建4个备份表的子线程

6)创建1个work thread后,g_async_queue_pop(conf.ready);此时conf.ready为空需要sleep等待。

7)work线程执行:连接mysql;设置隔离级别RR;start transaction;g_async_queue_push(conf->ready,GINT_TO_POINTER(1));然后main函数的g_async_queue_pop挂住的地方可以唤醒了,继续创建线程或者向下走。

8)work线程接着执行:进入死循环,从队列里pop出任务job=(struct job *)g_async_queue_pop(conf->queue);,根据任务类型进行dump。这里的并行是根据表并行的。先备份非事务表,然后备份innodb表

9)最后等所有work线程完成非事务表备份后唤醒g_async_queue_pop(conf.unlock_tables);,执行UNLOCK TABLES解锁

10)事务结束

fj.pngmydumper.png

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/31493717/viewspace-2153534/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/31493717/viewspace-2153534/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值