Chinaunix首页 | 论坛 | 博客
  • 博客访问: 7610087
  • 博文数量: 368
  • 博客积分: 9600
  • 博客等级: 上校
  • 技术积分: 18875
  • 用 户 组: 普通用户
  • 注册时间: 2009-01-01 00:00
文章分类

全部博文(368)

文章存档

2017年(9)

2016年(19)

2015年(3)

2014年(6)

2013年(8)

2012年(78)

2011年(66)

2010年(135)

2009年(44)

分类: Mysql/postgreSQL

2011-12-28 16:44:18

                                       mysql主从数据校验工具
      mysql在5.1之前,其replication都是采用的STATEMENT模式,对表的数据是否一致要求并不严格,所以对数据一致性要求比较严格的应用,定期检查数据一致性是很有必要的,mk-table-checksum就是一个很不错的检查工具。mk-table-checksum是包含在Maatkit脚本工具包中的一个,所以要用mk-table-checksum需要先安装Maatkit。

下载安装Maatkit
wget
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
阅读(4609) | 评论(0) | 转发(2) |
给主人留下些什么吧!~~