Maatkit工具使用<一>之mysql主从数据校验工具
2011-12-28 16:44
597 查看
mysql主从数据校验工具
mysql在5.1之前,其replication都是采用的STATEMENT模式,对表的数据是否一致要求并不严格,所以对数据一致性要求比较严格的应用,定期检查数据一致性是很有必要的,mk-table-checksum就是一个很不错的检查工具。mk-table-checksum是包含在Maatkit脚本工具包中的一个,所以要用mk-table-checksum需要先安装Maatkit。
下载安装Maatkit
wget http://maatkit.googlecode.com/files/maatkit-7540.tar.gz tar zxvf maatkit-7540.tar.gz
cd maatkit-7540
perl Makefile.PL
make install
注意:
在使用mk-table-checksum进行操作的时候,会对当前检查的表加一个表级锁,所以一般这类检查最好是在业务比较闲的时候进行。
使用mk-table-checksum进行表校验:
在被校验的主从服务器上创建只有SELECT权限的帐号
GRANT SELECT ON *.* TO 'test'@'%' IDENTIFIED BY 'test123';
mk-table-checksum常用参数说明:
-d 后接数据库名,如果不加-d,就是校验所有库或者用--databases,注意后面不需要加=号
--count 会计算出表的行数
例如:
我要检查master=192.168.0.1,slave=192.168.0.2的两台mysql的test库的表是否一致,命令如下:
mk-table-checksum h=192.168.0.1,u=test,p='test123' h=192.168.0.2,u=test,p='test123' -dtest --count
这里需要顺带介绍下mk-table-checksum的过滤工具mk-checksum-filter,例如我只想知道test库中哪些表不是一致的。只需要加一个管道符即可。
mk-table-checksum h=192.168.0.1,u=test,p='test123' h=192.168.0.2,u=test,p='test123' -dtest --count | mk-checksum-filter
参考:http://hi.baidu.com/ququ_s/blog/item/29c58c8c2a68890bb21bba66.html
mysql在5.1之前,其replication都是采用的STATEMENT模式,对表的数据是否一致要求并不严格,所以对数据一致性要求比较严格的应用,定期检查数据一致性是很有必要的,mk-table-checksum就是一个很不错的检查工具。mk-table-checksum是包含在Maatkit脚本工具包中的一个,所以要用mk-table-checksum需要先安装Maatkit。
下载安装Maatkit
wget http://maatkit.googlecode.com/files/maatkit-7540.tar.gz tar zxvf maatkit-7540.tar.gz
cd maatkit-7540
perl Makefile.PL
make install
注意:
在使用mk-table-checksum进行操作的时候,会对当前检查的表加一个表级锁,所以一般这类检查最好是在业务比较闲的时候进行。
使用mk-table-checksum进行表校验:
在被校验的主从服务器上创建只有SELECT权限的帐号
GRANT SELECT ON *.* TO 'test'@'%' IDENTIFIED BY 'test123';
mk-table-checksum常用参数说明:
-d 后接数据库名,如果不加-d,就是校验所有库或者用--databases,注意后面不需要加=号
--count 会计算出表的行数
例如:
我要检查master=192.168.0.1,slave=192.168.0.2的两台mysql的test库的表是否一致,命令如下:
mk-table-checksum h=192.168.0.1,u=test,p='test123' h=192.168.0.2,u=test,p='test123' -dtest --count
这里需要顺带介绍下mk-table-checksum的过滤工具mk-checksum-filter,例如我只想知道test库中哪些表不是一致的。只需要加一个管道符即可。
mk-table-checksum h=192.168.0.1,u=test,p='test123' h=192.168.0.2,u=test,p='test123' -dtest --count | mk-checksum-filter
参考:http://hi.baidu.com/ququ_s/blog/item/29c58c8c2a68890bb21bba66.html
相关文章推荐
- Maatkit工具使用<二>之mysql重复索引检测工具
- <一>Ioc控制反转——手把手教学:如何配置并使用单元测试一个spring框架(附源码)
- mysql 使用 workbench工具【E-R图 <--> 数据库】之间相互转换
- <一>Oracle11g的安装+数据库创建+PL/SQL Dev的使用初步
- Alfred工具使用<2>
- 【MySql】使用记录<一>
- <转>学习java反编译工具的使用
- <转>静态分析工具PMD使用说明
- <linux>adb fastboot 和VNC工具的安装使用
- <转>Android ORM 框架子 greenDao 使用心得
- Spring配置文件中使用ref local与ref bean的区别. 在ApplicationResources.properties文件中,使用<ref bean>与<ref local>方法如下
- 使用< OBJECT >标记引用对象
- 简述使用<iostream.h>与<iostream>命名空间std这两种形式有什么区别?
- <Linux+Qt>使用Qt绘制2D 图形 <五 图片变换>
- <转>android-滑动菜单栏-开源项目SlidingMenu的搭建和使用
- java "回调【 Callback 】" 的理解和使用<借鉴>
- <SVN>使用SVN小乌龟对比单个文件任意版本的差异
- thinkphp 在循环内使用<php></php>
- <Java>一个类bytebuffer使用
- 【Html】使用<pre>标签为你的网页加入大段代码