V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
推荐学习书目
Learn Python the Hard Way
Python Sites
PyPI - Python Package Index
http://diveintopython.org/toc/index.html
Pocoo
值得关注的项目
PyPy
Celery
Jinja2
Read the Docs
gevent
pyenv
virtualenv
Stackless Python
Beautiful Soup
结巴中文分词
Green Unicorn
Sentry
Shovel
Pyflakes
pytest
Python 编程
pep8 Checker
Styles
PEP 8
Google Python Style Guide
Code Style from The Hitchhiker's Guide
seanlook
V2EX  ›  Python

让 mysqldump 变成并发导出导入的魔法

  •  
  •   seanlook · 2016-12-01 13:00:32 +08:00 · 3031 次点击
    这是一个创建于 2917 天前的主题,其中的信息可能已经有所发展或是发生改变。

    mydumper 和 mysqlpump 在特定场景下会有些限制,于是自己用 python 封装 mysqldump ,实现以多线程的方式导出库表的操作,再以 mysql 命令多线程导入新库,用于成倍加快导出,特别是导入的速度。这一切只需要在 mysqldump 或 mysql 命令前面加上 mypumpkin.py 即可。

    Github 项目地址 https://github.com/seanlook/mypumpkin

    介绍和使用见 http://seanlook.com/2016/11/17/python-mysqldump-out-in-concurrency-magic/

    5 条回复    2016-12-02 15:34:22 +08:00
    xi_lin
        1
    xi_lin  
       2016-12-01 13:15:02 +08:00
    veelog
        2
    veelog  
       2016-12-01 13:18:16 +08:00 via Android
    有没有可以限制 mysqldump 速度的??现在执行 sqldump 整个数据库操作非常慢
    seanlook
        3
    seanlook  
    OP
       2016-12-01 13:44:41 +08:00
    @veelog 限流这个倒蛮新颖的,我这个工具一开起来基本上能把带宽或磁盘打满,源数据库 IO 会特别高。

    mydumper 可以做到表上的多并发,可以每次 select chunk sleep 几毫秒来实现...
    seanlook
        4
    seanlook  
    OP
       2016-12-01 13:45:11 +08:00
    @xi_lin 欢迎提建议...
    julyclyde
        5
    julyclyde  
       2016-12-02 15:34:22 +08:00
    限流(不基于数据语义)可以用 pv 工具
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5818 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 128ms · UTC 03:10 · PVG 11:10 · LAX 19:10 · JFK 22:10
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.