MySQL 使用pt-table-checksum 检查主从数据一致性 (实例转)
1、基本环境:
Mysql版本:5.6.12-log
Percona-toolkit:2.2.18
Linux:centos6.5
2、安装
源码安装:
|
# 一些依赖包 yum install perl perl-DBI perl-DBD-MySQL perl-IO-Socket-SSL perl-Time-HiRes -y # 下载安装percona-toolkit wget https://www.percona.com/downloads/percona-toolkit/2.2.18/tarball/percona-toolkit-2.2.18.tar.gz tar -xvf percona-toolkit_2.2.18.tar.gz cd percona-toolkit-2.2.18/ yum install perl-DBD-MySQL -y perl Makefile.PL make make test make install cp /usr/local/bin/pt* /bin/ |
Rpm包安装:
|
wget https://www.percona.com/downloads/percona-toolkit/2.2.18/RPM/percona-toolkit-2.2.18-1.noarch.rpm |
报错记录:
|
07-21T11:36:38 Error checksumming table business_db.SHOP_BARGAIN_RANGE: DBD::mysql::st execute failed: Unknown column 'db' in 'where clause' [for Statement "DELETE FROM `test`.`dsns` WHERE db = ? AND tbl = ?" with ParamValues: 0='business_db', 1='SHOP_BARGAIN_RANGE'] at /usr/local/bin/pt-table-checksum line 10085. |
需要安装perl源组件:
yum -y install perl-devel
yum -y install perl-CPAN
3、建立check账号
赋予权限:
|
mysql> grant SUPER on *.* to repl@'192.168.%'; Query OK, 0 rows affected (0.00 sec) mysql> mysql> grant PROCESS on *.* to repl@'192.168.%'; Query OK, 0 rows affected (0.00 sec) mysql> mysql> grant select,create,drop,insert,delete,update,alter on percona.* to repl@'192.168.%'; Query OK, 0 rows affected (0.00 sec) mysql> |
在主库建库建表:
|
# 默认的check库 Create database percona; # 准备测试库数据 Create database bg; Use bg; CREATE TABLE `t1` ( `id` int(1) NOT NULL AUTO_INCREMENT, `cname` varchar(3) NOT NULL DEFAULT '', PRIMARY KEY (`id`) ) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=utf8; insert into t1 select 1,’abc’; # 然后单独在从库录入数据,那么主从数据不一致了,从库多了一条数据 Insert into t1 select 2,’ab2’; |
开始使用pt-table-checksum检查:
|
# 执行checksum操作 [root@hch_test_dbm1_121_62 mysql]# pt-table-checksum --host=192.168.121.62 --port 3306 --databases=bg -urepl -pPlcc0805@replication --no-check-binlog-format [root@hch_test_dbm1_121_62 mysql]# # 没有check出来数据不一致的,why? 去执行select * from checksums;也没有记录。 mysql> select * from percona.checksums; Empty set (0.00 sec) mysql> |
换个mysql主从环境进行测试:
pt-table-checksum --host=110.251.13.11 --port 3307 --databases=test-u check_user -pPlcc0805@replication --no-check-binlog-format
执行报错:
Diffs cannot be detected because no slaveswere found. Please read the--recursion-method documentation for information.
从字面意思上看是,主库找不到从数据库。只需要在从库配置文件 my.cnf中添加
report_host=slave_ip
report_port=slave_port
即可。
如果slave从库有表t3,master主库没有t3表,那么结果集上不会显示出来说从库多了个表t3,它以主master库为基准来判断验证的。
4、Test库能check,enrolment_db不能check
|
# 开始检查test库的所有表 [root@azure_zhitian_dbm1_13_11 ~]# pt-table-checksum --host=110.251.13.11 --port 3307 --databases=test --user=check_user --password="Plcc0805@replication" --no-check-binlog-format TS ERRORS DIFFS ROWS CHUNKS SKIPPED TIME TABLE 07-28T16:34:23 0 0 1 1 0 0.358 test.JBPM4_EXECUTION 07-28T16:34:23 0 1 2 1 0 0.038 test.t1 [root@azure_zhitian_dbm1_13_11 ~]# n 看到test.t1表的DIFFS为1,表示关于test.t1表的主从数据不一致,需要修复 # 再检查 enrolment_db库,没有记录,这是为啥? [root@azure_zhitian_dbm1_13_11 ~]# pt-table-checksum --host=110.251.13.11 --port 3307 --databases=enrolment_db --user=check_user --password="Plcc0805@replication" --chunk-size=100 --no-check-binlog-format [root@azure_zhitian_dbm1_13_11 ~]# |
MySQL 使用pt-table-checksum 检查主从数据一致性 (实例转)的更多相关文章
- pt-table-checksum 检查主从数据一致性
http://www.cnblogs.com/xiaoyanger/p/5584554.html http://www.cnblogs.com/gomysql/p/3662264.html https ...
- 利用mk-table-checksum监测Mysql主从数据一致性操作记录
前面已经提到了mysql主从环境下数据一致性检查:mysql主从同步(3)-percona-toolkit工具(数据一致性监测.延迟监控)使用梳理今天这里再介绍另一种Mysql数据一致性自动检测工具: ...
- MySQL主从数据一致性问题修复
MySQL主从数据一致性问题修复 前面,我们使用pt-table-checksum 可以检测出主从数据是否一致的问题.发现问题后,我们怎么解决这些问题,也是我们必须要会的技能. 修复主从数据一致性问题 ...
- pt工具校验主从数据一致性之dsns方式
mysql主从数据一致性校验,常用的方法是Percona-Toolkit的组件pt-table-checksum,这东西怎么用网上一大堆,就不啰嗦了.主要说一下通过dsns方式发现从库的一种方式. p ...
- MySQL 主主同步配置和主从配置步骤
★预备知识 : 1.双机热备 对于双机热备这一概念,我搜索了很多资料,最后,还是按照大多数资料所讲分成广义与狭义两种意义来说. 从广义上讲,就是对于重要的服务,使用两台服务器,互相备份,共同执行同一服 ...
- 使用pt-table-checksum检查主从一致性
使用 percona 工具检查主从不一致 可以使用 pt-table-checksum 工具检查主从数据的一致性,检查完之后默认会生成一个 percona 库以及一个 checksums 表,记录了 ...
- MySQL 出现 The table is full 的解决方法【转】
[MySQL FAQ]系列 — 你所不知的table is full那些事 时间 2014-08-21 12:18:56 MySQL中文网 原文 http://imysql.com/2014/08 ...
- sqoop import mysql to hive table:GC overhead limit exceeded
1. Scenario description when I use sqoop to import mysql table into hive, I got the following error: ...
- MYSQL - database 以及 table 的增删改查
MYSQL - database 以及 table 的增删改查 MySQL的相关概念介绍 MySQL 为关系型数据库(Relational Database Management System), 这 ...
随机推荐
- Windows定时任务没有执行
最近部署网站首页静态化程序,需要定时执行的,由于部署在Windows上,为了方便直接用Windows计划任务做定时了.跑了一段时间发现.首页的静态html文件日期一直是老的,手动执行程序会更新,怀疑任 ...
- awk的getline命令
原文出处:生活费的博客,http://www.cnblogs.com/276815076/archive/2011/12/05/2276625.html#undefined 两种情况:getline ...
- PHP的垃圾回收机制以及大概实现
垃圾回收,简称gc.顾名思义,就是废物重利用的意思.再说这个之前先接触一下内存泄露,大概意思就是申请了一块地儿拉了会儿屎,拉完之后不收拾,那么这块地就算糟蹋了,地越用越少,最后一地全是屎.说到底一句, ...
- Cocos2d-x项目移植到WP8系列之六:C#工程使用C++的DLL
原文链接: http://www.cnblogs.com/zouzf/p/3984510.html 此时,一些大问题都被解决后,整个工程基本能跑起来了,最后一个大问题是:业务层是用Lua开发的,底层的 ...
- 2.virtualenv安装和配置以及在PyCharm中如何使用虚拟环境
virtualenv优点 使不同应用开发环境相互独立 环境升级不影响其它应用,也不会影响全局的python环境 它可以防止系统中出现包管理混乱和版本的冲突 1.使用virtualenv pip ins ...
- 1028: [JSOI2007]麻将
1028: [JSOI2007]麻将 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 2638 Solved: 1168[Submit][Status] ...
- maven 中pom.xml文件依赖包从本地加载如何配置?
比如我现在有一个需求是:项目中要加载ueditor的jar架构包,并且用maven构建的项目 那么在pom.xml文件中如配置: 说明:${project.basedir} 是maven 自带(内置) ...
- Mysql -- SQL常用命令实例
sql: structured query language(结构化查询语言) 用户名和密码:root 创建一个名称为mydb1的数据库. create database mydb1; 查看所有数据库 ...
- shell学习之常用技巧
cut 切割,-d分隔符,-f指定段号,-c指定第几个字符.d,f用的多些. sort排序,-n按照数字排序,-r反排序. wc -l 查看文件行数. 大道至简,掌握常用的命令就可以了. uniq去重 ...
- spring: 使用嵌入式数据源 EmbeddedDatabaseBuilder
嵌入式数据源作为应用的一部分运行,非常适合在开发和测试环境中使用,但是不适合用于生产环境.因为在使用嵌入式数据源的情况下,你可以在每次应用启动或者每次运行单元测试之前初始化测试数据. 使用Spring ...