zoukankan      html  css  js  c++  java
  • Maatkit工具使用<一>之mysql主从数据校验工具

                                           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
  • 相关阅读:
    原型,原型对象,原型链,构造函数,继承(一)
    暑假闲着没事第一弹:基于Django的长江大学教务处成绩查询系统
    ANDROID自定义视图——onMeasure流程,MeasureSpec详解
    android 中发送短信
    VelocityTracker简介
    Android xml资源文件中@、@android:type、@*、?、@+含义和区别
    android:id="@+id/android:empty属性的用法举例
    Android ProgressBar详解以及自定义
    Android自定义进度条
    布局技巧:使用ViewStub
  • 原文地址:https://www.cnblogs.com/feihongwuhen/p/7169890.html
Copyright © 2011-2022 走看看