news 2026/6/10 3:07:04

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/9 20:09:38

泛微OA手机号校验及下拉后禁用

手机号校验: WfForm.bindFieldChangeEvent("field8922", function(obj, id, value) {// 手机号正则:11位,以1开头,第二位3-9,后9位数字var phoneReg = /^1[3-9]\d{9}$/;// 如果值不为空且不符合手机号格式if (value && (value.length != 11 || !phoneRe…

作者头像 李华
网站建设 2026/6/9 18:57:36

BioSIM抗人APRIL/CD256 抗体SIM0360:多样化的应用支持

在现代生物制药领域&#xff0c;抗体药物因其高度特异性和强大的治疗潜力&#xff0c;成为疾病治疗的重要工具。其中&#xff0c;针对APRIL/CD256靶点的抗体药物&#xff0c;在自身免疫性疾病、炎症相关疾病以及肿瘤免疫治疗中展现出广阔的应用前景。作为一款高质量的生物类似药…

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

LobeChat能否接入LinkedIn API?职业发展建议机器人

LobeChat能否接入LinkedIn API&#xff1f;职业发展建议机器人 在职场竞争日益激烈的今天&#xff0c;越来越多的人开始寻求个性化的成长路径——但传统的职业咨询往往价格高昂、信息滞后&#xff0c;且依赖用户手动填写冗长的简历表单。如果AI能自动读取你最新的LinkedIn履历…

作者头像 李华
网站建设 2026/6/9 7:14:41

Vue.js 报错:Component “xxx“ should be a constructor

Vue.js 报错&#xff1a;Component “xxx” should be a constructor —— 3 分钟急救手册 正文目录 报错含义&#xff1a;Vue 在挑剔什么“构造函数”&#xff1f;4 大高频翻车场景 & 修复代码兼容性方案&#xff1a;旧库/第三方组件适配预防 checklist&#xff08;不再踩…

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

Seed-Coder-8B-Base与Codex代码生成对比

Seed-Coder-8B-Base与Codex代码生成对比&#xff1a;谁才是企业级智能编码的未来&#xff1f; 在一家金融科技公司的深夜会议室里&#xff0c;开发团队正为是否引入AI编程助手争论不休。有人主张接入GitHub Copilot——“效率提升立竿见影”&#xff1b;另一派则坚持自建系统&a…

作者头像 李华
网站建设 2026/6/4 22:57:24

雷科电力-REKE-WS瓦斯继电器自动测试仪

一、概念&#xff1a;轻瓦斯&#xff1a;当变压器内部发生轻微故障时&#xff0c;瓦斯产生的速度较缓慢&#xff0c;瓦斯上升至储油柜途中首先积存于瓦斯继电器的上部空间&#xff0c;使油面下降&#xff0c;浮筒随之下降而使水银接点闭合&#xff0c;接通报警信号。重瓦斯&…

作者头像 李华