转载自:https://www.cnblogs.com/abclife/p/7755031.html
Mydumper是一个针对MySQL和Drizzle的高性能多线程备份和恢复工具。开发人员主要来自MySQL,Facebook,SkySQL公司。目前已经在一些线上使用了Mydumper。
一、Mydumper主要特性:
-执行并行(速度快)、性能提升
-易于管理
-一致性:在所有的threads之间维护快照,提供master和slave日志的准确位置等
-管理型:支持PCRE
默认是关闭了binlog的dump功能,要想开启,需要在cmke编译的时候添加-DWITH_BINLOG=ON
二、如何获取一致性快照的:
-server上正在运行的慢查询或中断dump,或者慢查询被kill掉
-需要施加全局写锁("flush tables with read lock")
-读取不同的元数据("show slave status","show master status")
-具有事务性和非事务性表一致的快照(0.2.2+)
-一旦所有的工作现成通知已经创建好快照,master会执行"unlock tables",开始运行队列中的job
三、mydumper的工作原理:
mydumper的主要工作步骤:
1 主线程 flush tables with read lock, 施加全局只读锁,以阻止dml语句写入,保证数据的一致性
2 读取当前时间点的二进制日志文件名和日志写入的位置并记录在metadata文件中,以供恢复使用
3 start transaction with consistent snapshot; 开启读一致事务
4 启用n个(线程数可以指定,默认是4)dump线程导出表和表结构
5 备份非事务类型的表
6 主线程 unlock tables,备份完成非事务类型的表之后,释放全局只读锁
7 基于事务dump innodb tables
8 事务结束
四、mydumper的安装:
# yum install glib2-devel mysql-devel zlib-devel pcre-devel openssl-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 .
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
|
# cmake . -- The C compiler identification is GNU 4.8.5 -- The CXX compiler identification is GNU 4.8.5 -- Check for working C compiler: /bin/cc -- Check for working C compiler: /bin/cc -- works -- Detecting C compiler ABI info -- Detecting C compiler ABI info - done -- Check for working CXX compiler: /bin/c ++ -- Check for working CXX compiler: /bin/c ++ -- works -- Detecting CXX compiler ABI info -- Detecting CXX compiler ABI info - done -- Using mysql-config: /bin/mysql_config -- Found MySQL: /usr/include/mysql , /usr/lib64/mysql/libmysqlclient .so; /usr/lib64/libpthread .so; /usr/lib64/libz .so; /usr/lib64/libm .so; /usr/lib64/libssl .so; /usr/lib64/libcrypto .so; /usr/lib64/libdl .so -- Found ZLIB: /usr/lib64/libz .so (found version "1.2.7" ) -- Found PkgConfig: /bin/pkg-config (found version "0.27.1" ) -- checking for one of the modules 'glib-2.0' -- checking for one of the modules 'gthread-2.0' -- checking for module 'libpcre' -- found libpcre, version 8.32 -- Found PCRE: /usr/include CMake Warning at docs /CMakeLists .txt:9 (message): Unable to find Sphinx documentation generator -- ------------------------------------------------ -- MYSQL_CONFIG = /bin/mysql_config -- CMAKE_INSTALL_PREFIX = /usr/local -- BUILD_DOCS = ON -- WITH_BINLOG = OFF -- RUN_CPPCHECK = OFF -- Change a values with: cmake -D<Variable>=<Value> -- ------------------------------------------------ -- -- Configuring done -- Generating done -- Build files have been written to: /root/mydumper-0 .9.1 |
# make
1
2
3
4
5
6
7
8
9
10
11
|
# make Scanning dependencies of target mydumper [ 25%] Building C object CMakeFiles /mydumper . dir /mydumper .c.o [ 50%] Building C object CMakeFiles /mydumper . dir /server_detect .c.o [ 75%] Building C object CMakeFiles /mydumper . dir /g_unix_signal .c.o Linking C executable mydumper [ 75%] Built target mydumper Scanning dependencies of target myloader [100%] Building C object CMakeFiles /myloader . dir /myloader .c.o Linking C executable myloader [100%] Built target myloader |
# make install
1
2
3
4
5
6
7
8
9
|
# make install [ 75%] Built target mydumper [100%] Built target myloader Install the project... -- Install configuration: "" -- Installing: /usr/local/bin/mydumper -- Removed runtime path from "/usr/local/bin/mydumper" -- Installing: /usr/local/bin/myloader -- Removed runtime path from "/usr/local/bin/myloader" |
安装好之后 ,会生成两个文件:
1
2
|
/usr/local/bin/mydumper /usr/local/bin/myloader |
五、参数说明:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
|
-B, --database 要导出的数据库名 -T, --tables-list 要导出的表名,多个表用逗号分隔。不支持正则表达式 -o, --outputdir 导出数据文件存放的目录,mydumper会自动创建 -s, --statement-size 生成插入语句的字节数, 默认1000000字节 -r, --rows Try to split tables into chunks of this many rows. This option turns off --chunk-filesize -F, --chunk-filesize Split tables into chunks of this output file size. This value is in MB -c, --compress 压缩导出的文件 -e, --build-empty-files 即使是空表也为表创建文件 -x, --regex 使用正则表达式匹配'db.table' -i, --ignore-engines 忽略的存储引擎,多个存储引擎使用逗号分隔 -m, --no-schemas 只导出数据,不导出建库建表语句 -d, --no-data 仅仅导出建表结构,创建db的语句,不导出表的数据 -G, --triggers 导出触发器 -E, --events 导出events -R, --routines 导出存储过程和函数 -k, --no-locks 不施加临时的共享读锁,会导致备份不一致 --less-locking 最小化在innodb表上的锁表时间 -l, --long-query-guard 设置长查询定时器,单位是秒,默认是60 -K, --kill-long-queries Kill掉运行时间长的查询 -D, --daemon 以守护进程的方式执行 -I, --snapshot-interval 创建导出快照的时间间隔,默认是 60s ,该参数只有在守护进程执行的时候有用 -L, --logfile 指定mydumper输出的日志文件,默认使用控制台输出 --tz-utc SET TIME_ZONE='+00:00' at top of dump to allow dumping of TIMESTAMP data when a server has data in different time zones or data is being moved between servers with different time zones, defaults to on use --skip-tz-utc to disable. --skip-tz-utc --use-savepoints 使用savepoints减少对元数据锁定的问题,需要SUPER权限 --success-on-1146 Not increment error count and Warning instead of Critical in case of table doesn't exist --lock-all-tables Use LOCK TABLE for all, instead of FTWRL -U, --updated-since Use Update_time to dump only tables updated in the last U days --trx-consistency-only Transactional consistency only -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, 默认为2 |
六、mydump导出的文件类型
1
2
3
4
|
metadata :包含导出开始和结束时间,如果开启binlog会记录日志位置信息;如果启用gtid ,则记录gtid信息。 db. table .sql :数据文件, insert 语句 db. table - schema .sql :包含建表语句 db- schema .sql :包含建库语句 |