news 2026/6/15 19:43:37

pt-table-checksum 使用指南:在binlog格式为ROW的从库上使用时的注意细节

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
pt-table-checksum 使用指南:在binlog格式为ROW的从库上使用时的注意细节

pt-table-checksum可以在binlog格式为ROW的从库上运行,但需要正确配置。

工作原理

pt-table-checksum通过在主库上执行校验和查询,并利用MySQL复制机制将结果传播到从库:

  1. 在主库计算数据块的校验和
  2. 结果写入percona.checksums
  3. 通过复制同步到从库
  4. 在从库比较本地数据与主库传来的校验和

ROW格式下的特殊考虑

需要满足的条件:

  1. 启用binlog(无论主从)
  2. 设置binlog_format = STATEMENT用于校验和操作:
    -- 会话级设置(推荐)SETSESSIONbinlog_format='STATEMENT';-- 或者在my.cnf中为特定用户设置

正确的执行方式:

# 推荐:让工具自动处理格式转换pt-table-checksum\--replicate=percona.checksums\--no-check-binlog-format\--empty-replicate-table\--create-replicate-table\--recursion-method=hosts\h=主库IP,u=用户,p=密码# 或者显式设置pt-table-checksum\--set-vars"binlog_format=STATEMENT"\--replicate=percona.checksums\h=主库IP

常见问题和解决方案:

问题原因解决方案
复制错误ROW格式无法执行校验和语句使用--set-vars或让工具自动转换
权限不足需要SUPER权限改会话变量授予用户SUPER权限
不一致结果从库也在写入数据使用--pause-file控制节奏

推荐的最佳实践:

  1. 在主库执行(而不是直接在从库):

    pt-table-checksum\--replicate=percona.checksums\--no-check-binlog-format\--max-lag=1s\--check-interval=2\--recursion-method=dsn=D=percona,t=dsns\h=master_host
  2. 配置示例(my.cnf):

    [mysqld] # 默认可以保持ROW格式 binlog_format = ROW # pt-table-checksum所需 binlog_rows_query_log_events = ON log_slave_updates = ON
  3. 检查结果

    # 在从库上检查差异SELECT db, tbl, SUM(this_cnt)AS total_rows, COUNT(*)AS chunks FROM percona.checksums WHERE master_cnt<>this_cnt OR master_crc<>this_crc GROUP BY db, tbl;

注意事项

  • pt-table-checksum总是在主库执行计算
  • 从库只需要能够正常复制并读取校验和结果
  • ROW格式本身不阻止校验,但校验过程需要STATEMENT格式
  • ⚠️ 如果从库有写入(如双主架构),需格外小心
  • ⚠️ 大表可能产生大量binlog,建议在低峰期进行
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 14:31:52

关系型数据库主流内容校验工具整理及介绍

主流校验工具对比工具原理优点缺点性能pt-table-checksum分块CRC32校验成熟、安全、自动分块慢、大表压力大⭐⭐MySQL Enterprise Checksum内置CHECKSUM TABLE原生、简单全表锁、无分块⭐gh-ost在线DDL时校验无触发器、可并行仅限迁移过程⭐⭐⭐⭐Percona Toolkit (新)增强版校…

作者头像 李华
网站建设 2026/6/15 12:36:36

TensorFlow镜像加速下载:使用清华源提升AI开发效率

TensorFlow镜像加速下载&#xff1a;使用清华源提升AI开发效率 在人工智能项目开发中&#xff0c;最让人沮丧的场景之一莫过于&#xff1a;刚搭建好开发环境&#xff0c;满怀期待地敲下 pip install tensorflow&#xff0c;结果命令行卡在“Collecting tensorflow”长达十几分…

作者头像 李华
网站建设 2026/6/15 12:35:55

USB设备ID数据库:厂商与设备型号对照表

USB设备ID数据库&#xff1a;厂商与设备型号对照表 在日常的系统维护、驱动开发或硬件调试中&#xff0c;你是否曾遇到过一个未知的USB设备插入后&#xff0c;系统只显示一串冰冷的VID:PID代码&#xff1f;面对046d:082d这样的标识&#xff0c;普通用户可能束手无策&#xff0c…

作者头像 李华
网站建设 2026/6/15 16:54:35

Java集合-Queue讲解

目录一、集合框架层次结构二、Collection集合1、Queue队列1. LinkedList 作为队列2. ArrayDeque 作为队列3. PriorityQueue 优先队列4.LinkedBlockingQueue - 最常用的阻塞队列5. ConcurrentLinkedQueue - 高并发非阻塞队列2、队列操作模式对比1.插入操作对比2.移除操作对比3.查…

作者头像 李华
网站建设 2026/6/15 9:33:15

AI不会淘汰产品经理,但不会AI的会!大模型学习指南(建议收藏)

文章强调AI时代已全面到来&#xff0c;产品经理必须拥抱AI避免被淘汰。作者建议向取得实际成果的人学习AI知识&#xff0c;而非纯理论。特别推荐参加人人都是产品经理大会&#xff0c;邀请了腾讯音乐、金山办公、字节跳动等有AI落地经验的产品经理分享实战经验。我不想给你们罗…

作者头像 李华