percona-toolkit之pt-table-sync

  

通过上面pt-table-checksums找到了这些不一致的数据表
(https://blog.51cto.com/li02yu/2340403)
,如何同步数据呢?即如何修复MySQL主从不一致的数据,让他们保持一致性呢?利用另外一个工具pt-table-sync。
使用方法:

  

<代码> pt-table-sync[选项]DSN (DSN)

  

pt-table-sync:高效的同步MySQL表之间的数据,他可以做单向和双向同步的表数据。他可以同步单个表,也可以同步整个库。它不同步表结构,索引,或任何其他模式对象,所以在修复一致性之前需要保证他们表存在。

  

通过(打印)打印出来修复一个表数据的sql语句

  
 <代码> [lxh@MySQL-01 ~] # pt-table-sync——打印数据库表==测试——test1——sync-to-master h=172.31.153.164, u=lxh, p=Mysql.163, p=3306  
  

通过(打印)打印出来修复一个库数据的sql语句

  
 <代码> [lxh@MySQL-01 ~] # pt-table-sync——打印数据库测试——sync-to-master h==172.31.153.164, u=lxh, p=Mysql.163, p=3306  
  

通过(打印)打印出来修复所有数据库的sql语句(不建议这样使用)

  
 <代码> [lxh@MySQL-01 ~] # pt-table-sync——打印sync-to-master h=172.31.153.164, u=lxh, p=Mysql.163, p=3306  
  
 <代码>参数的意义:
  复制代码
  
  ——复制=:指定通过pt-table-checksum得到的表,这2个工具差不多都会一直用。不指定,则使用默认的
  ——数据库=:指定执行同步的数据库,多个用逗号隔开。
  ——表=:指定执行同步的表,多个用逗号隔开。
  ——sync-to-master:指定一个DSN,即从的IP,他会通过processlist显示或显示奴隶状态去自动的找主。
  h=172.31.153.164:服务器地址,奴隶的地址。
  u=lxh:帐号。
  p=Mysql。163:密码。
  
  ——打印:打印,但不执行命令。
  ——执行:执行命令。 
  

一起解释下执行的效果:通过(打印)打印出来了修复数据的sql语句,可以手动的去从行执行,让他们数据保持一致性。那能否直接执行吗?当然可以,通过(执行)

  
 <代码> lxh@MySQL-01 ~ # pt-table-sync h=172.31.153.164, u=lxh, p=Mysql。163——执行 
  

没发现任何异常,然后检查主从数据的一致性:

  
 <代码> [lxh@MySQL-01 ~] # pt-table-checksum - u - p 'Mysql 'lxh”。163年-h272.31.153.163——数据库=测试——nocheck-binlog-format nocheck-plan——nocheck-replication-filters recursion-method=processlist
  TS差别行块跳过一次表错误
  04-13T16:27:28 0 0 3 1 0 0.097 test.test1  
  

好的,数据已经保持一致了。不过建议还是用——打印打印出来的好,这样就可以知道那些数据有问题,可以人为的干预下。不然直接执行了,出现问题之后更不好处理。总之还是在处理之前做好数据的备份工作。

  

注意:要是表中没有唯一索引或则主键则会报错:

  
 <代码>不能修改主因为不存在惟一索引/usr/local/bin/pt-table-sync第10591行。
  需要给表添加主键或唯一索引即可 

percona-toolkit之pt-table-sync