MySQL主从数据一致性问题修复

前面,我们使用pt-table-checksum 可以检测出主从数据是否一致的问题。发现问题后,我们怎么解决这些问题,也是我们必须要会的技能。

修复主从数据一致性问题,我们使用pt-table-sync工具,和pt-table-checksum一样,都需要提前安装percona-tools工具包。怎么安装,我这里就不说了,请看我之前的文章。

下面我们来演示一下主从数据一致性问题修复

1.环境介绍

IP 端口 角色
192.168.199.230 3306 Master
192.168.199.131 3306 Slave

我们这里已经创建好了主从复制环境,这里我就不演示了

2.创建表和数据

我们是在Master实例上创建表和数据

root@localhost:mysql3306.sock [db1]> create table tb_2018 (
-> id int not null auto_increment,
-> cname varchar(32),
-> ctime datetime,
-> primary key(id)
-> );
root@localhost:mysql3306.sock [db1]> insert into tb_2018(cname,ctime) values ('unixfbi',now());
Query OK, 1 row affected (0.00 sec) root@localhost:mysql3306.sock [db1]> insert into tb_2018(cname,ctime) values ('MySQL',now());
Query OK, 1 row affected (0.00 sec) root@localhost:mysql3306.sock [db1]> insert into tb_2018(cname,ctime) values ('JAVA',now());

3.让主从数据不一致

我们在从库上添加一条数据,让主从数据不一致。

oot@localhost [db1]>insert into tb_2018(cname,ctime) values ('NET',now());
Query OK, 1 row affected (0.02 sec)
root@localhost [db1]>select * from tb_2018;
+----+---------+---------------------+
| id | cname | ctime |
+----+---------+---------------------+
| 1 | unixfbi | 2018-01-29 14:43:01 |
| 2 | MySQL | 2018-01-29 14:43:10 |
| 3 | JAVA | 2018-01-29 14:43:19 |
| 4 | NET | 2018-01-29 14:44:15 |
+----+---------+---------------------+
4 rows in set (0.00 sec)

4.验证主从数据是否一致

在Master实例上执行

# pt-table-checksum --nocheck-binlog-format --replicate=db1.checksum   -h localhost -P3306 -u root -p unixfbi --ignore-databases=mysql --recursion-method="processlist"
Checking if all tables can be checksummed ...
Starting checksum ...
TS ERRORS DIFFS ROWS CHUNKS SKIPPED TIME TABLE
01-29T14:45:30 0 0 44 1 0 0.496 db1.tb1
01-29T14:45:30 0 1 3 1 0 0.015 db1.tb_2018
01-29T14:45:30 0 0 1 1 0 0.264 db2.tb3
01-29T14:45:31 0 0 1 1 0 0.012 db2.tb4
01-29T14:45:31 0 0 6 1 0 0.013 sys.sys_config
01-29T14:45:31 0 0 2 1 0 0.013 wbx3306.t1
01-29T14:45:31 0 0 0 1 0 0.013 wbx3306.tp_1

发现db1.tb_2018这个表里的数据已经不一致了。

5.查看不一致信息

执行pt-table-sync命令之前一定要确保checksum表的存在,也就是说必须先验证数据是否一致,才能执行pt-table-sync命令。

这里我们只是查看并打印解决不一致问题的语句,所以我们这里使用pt-table-sync命令的--print参数。修复不一致的问题,我们需要使用--execute参数。

# pt-table-sync --replicate=db1.checksum  h=192.168.199.230,u=root,p=unixfbi --print
DELETE FROM `db1`.`tb_2018` WHERE `id`='4' LIMIT 1 /*percona-toolkit src_db:db1 src_tbl:tb_2018 src_dsn:h=192.168.199.230,p=...,u=root dst_db:db1 dst_tbl:tb_2018 dst_dsn:h=dev-hd-node3,p=...,u=root lock:1 transaction:1 changing_src:db1.checksum replicate:db1.checksum bidirectional:0 pid:42455 user:ruowei host:db-node1*/;

直接打印出了解决主从数据不一致的语句。

6.修复主从数据不一致问题

这里我们需要使用pt-table-sync命令的--execute参数

# pt-table-sync --replicate=db1.checksum  h=192.168.199.230,u=root,p=unixfbi --execute

执行修复命令后,我们再次检查看看数据是否一致。

# pt-table-checksum --nocheck-binlog-format --replicate=db1.checksum   -h localhost -P3306 -u root -p unixfbi --ignore-databases=mysql --recursion-method="processlist"
Checking if all tables can be checksummed ...
Starting checksum ...
TS ERRORS DIFFS ROWS CHUNKS SKIPPED TIME TABLE
01-29T15:13:50 0 0 44 1 0 0.016 db1.tb1
01-29T15:13:50 0 0 3 1 0 0.015 db1.tb_2018
01-29T15:13:50 0 0 1 1 0 0.013 db2.tb3
01-29T15:13:50 0 0 1 1 0 0.012 db2.tb4
01-29T15:13:50 0 0 6 1 0 0.012 sys.sys_config
01-29T15:13:50 0 0 2 1 0 0.012 wbx3306.t1
01-29T15:13:50 0 0 0 1 0 0.013 wbx3306.tp_1

发现没有显示数据不一致的问题。

在从库上查看一下数据有什么变化:

root@localhost [db1]>select * from tb_2018;
+----+---------+---------------------+
| id | cname | ctime |
+----+---------+---------------------+
| 1 | unixfbi | 2018-01-29 14:43:01 |
| 2 | MySQL | 2018-01-29 14:43:10 |
| 3 | JAVA | 2018-01-29 14:43:19 |
+----+---------+---------------------+
3 rows in set (0.00 sec)

发现是把id=4的这条数据删除了,保证了和主库数据一致性的。

参考文档

http://blog.itpub.net/12679300/viewspace-1455303/

本文出自 “运维特工” 博客,转载请务必保留原文链接 和 http://www.unixfbi.com

MySQL主从数据一致性问题修复的更多相关文章

  1. mysql主从数据一致性校验和修复

    1. 安装 yum install -y perl-IO-Socket-SSL.noarch perl-Digest-MD5 yum -y install http://www.percona.com ...

  2. 利用mk-table-checksum监测Mysql主从数据一致性操作记录

    前面已经提到了mysql主从环境下数据一致性检查:mysql主从同步(3)-percona-toolkit工具(数据一致性监测.延迟监控)使用梳理今天这里再介绍另一种Mysql数据一致性自动检测工具: ...

  3. 恢复MySQL主从数据一致性的总结

    今日上午,同事告知,MySQL主从数据库的数据不一致,猜测备库在同步过程中出现了问题,于是,登上备库,使用 mysql> show slave status\G查看,果然,备库在insert语句 ...

  4. pt-table-checksum校验mysql主从数据一致性

    主从数据的一致性校验是个头疼的问题,偶尔被业务投诉主从数据不一致,或者几个从库之间的数据不一致,这会令人沮丧.通常我们仅有一种办法,热备主库,然后替换掉所有的从库.这不仅代价非常大,而且类似治标不治本 ...

  5. mysql主从同步(3)-percona-toolkit工具(数据一致性监测、延迟监控)使用梳理

    转自:http://www.cnblogs.com/kevingrace/p/6261091.html 在mysql工作中接触最多的就是mysql replication mysql在复制方面还是会有 ...

  6. mysql主从同步(4)-Slave延迟状态监控

    mysql主从同步(4)-Slave延迟状态监控  转自:http://www.cnblogs.com/kevingrace/p/5685511.html 之前部署了mysql主从同步环境(Mysql ...

  7. pt工具校验主从数据一致性之dsns方式

    mysql主从数据一致性校验,常用的方法是Percona-Toolkit的组件pt-table-checksum,这东西怎么用网上一大堆,就不啰嗦了.主要说一下通过dsns方式发现从库的一种方式. p ...

  8. MySQL主从修复

    MySQL主从故障修复 测试库:192.168.1.2 主192.168.1.3 从 192.168.1.4 主 4又是2的从库192.168.1.5 从 有人修改了192.168.1.2和192.1 ...

  9. shell脚本修复MySQL主从同步

    发布:thebaby   来源:net     [大 中 小] 分享一例shell脚本,用于修改mysql的主从同步问题,有需要的朋友参考下吧. 一个可以修改mysql主从同步的shell脚本. 例子 ...

随机推荐

  1. Ubuntu 上 执行命令 java -version 显示 没有那个文件或目录

    解决方法 执行 which java 发现默认java目录:/usr/bin/java . 查看 JAVA_HOME 路径:$JAVA_HOME,得到 /usr/local/java/jdk1.7.0 ...

  2. shell case语句

    case 格式 case 值 in 模式1) command1 command2 ... commandN ;; 模式2) command1 command2 ... commandN ;; esac ...

  3. Springboot 编码规范

    1.规范的意义和作用 编码规范可以最大限度的提高团队开发的合作效率 编码规范可以尽可能的减少一个软件的维护成本 , 并且几乎没有任何一个软件,在其整个生命周期中,均由最初的开发人员来维护 编码规范可以 ...

  4. Java 打开Excel,往Excel中存入值,保存的excel格式分别是xls和xlsx

    https://mirrors.cnnic.cn/apache/poi/xmlbeans/release/src/ package Excel; import org.apache.poi.hssf. ...

  5. STL_容器使用时机

    1. 来自教程: ◆ Vector的使用场景:比如软件历史操作记录的存储,我们经常要查看历史记录,比如上一次的记录,上上次的记录,但却不会去删除记录,因为记录是事实的描述. ◆ deque的使用场景: ...

  6. Typekit在线字库及使用方法

    一.如果设计中使用了非标准的字体,你该如何去实现? 所谓的标准字体是多数机器上都会有的,或者即使没有也可以由默认字体替代的字体. 方法: 用图片代替 web fonts在线字库,如Google Web ...

  7. mysql 问题 Loading class `com.mysql.jdbc.Driver'. This is deprecated. The new driver class is `com.mysql.cj.jdb

    异常错误:Loading class `com.mysql.jdbc.Driver'. This is deprecated. The new driver class is `com.mysql.c ...

  8. gradle 编译 No such property: sonatypeUsername错误解决

    No such property: sonatypeUsername for class: org.gradle.api.publication.maven.internal.ant.DefaultG ...

  9. Docker 构建 redis 集群

    安装docker 1.yum install docker 方法一: 1. docker pull redis 2.docker run -d --name redis-1 -p 7001:6379 ...

  10. Python基础--列表、元组

    一.什么是列表.元组 序列是Python中最基本的数据结构.序列中的每个元素都分配一个数字 - 它的位置,或索引,第一个索引是0,第二个索引是1,依此类推. Python有6个序列的内置类型,但最常见 ...