当前位置: 首页 > news >正文

mysql复制延迟如何处理

一、复制延迟的原因

  • 主库增删改并发大
  • 大表在做DDL
  • 从库备份导致延迟
  • 大事务
  • 从库机器配置差

二、怎样判断延迟

使用 SHOW SLAVE STATUS 命令

  • Seconds_Behind_Master:表示从库落后主库的秒数(若为 NULL,可能复制线程已停止)
  • 对比位点
字段名含义说明
Master_Log_File从库的 IO 线程正在读取的主库 binlog 文件名
Read_Master_Log_Pos从库的 IO 线程已读取到的主库 binlog 位点
Relay_Master_Log_File从库的 SQL 线程正在执行的事务对应的主库 binlog 文件名
Exec_Master_Log_Pos从库的 SQL 线程已执行到的主库 binlog 位点
  • 对比GTID
字段名说明
Auto_Position为 1 表示启用了 GTID 复制
Retrieved_Gtid_Set从库已接收的所有事务的 GTID 集合
Executed_Gtid_Set从库已执行的所有事务的 GTID 集合

 无延迟
Retrieved_Gtid_Set == Executed_Gtid_Set,表示从库已全部执行完主库传来的事务。

有延迟
Executed_Gtid_SetRetrieved_Gtid_Set真子集,说明还有事务未执行完。

三、主从延迟处理方法

1、开启多线程

2、调整一些MySQL的参数

以下是对 innodb_flush_log_at_trx_commitsync_binlog 两个参数的表格形式介绍,以及在主从因 IO 延迟时的建议:

参数名称允许值描述建议(主从 IO 延迟场景)
innodb_flush_log_at_trx_commit0, 1, 2控制 InnoDB Redo Log 的写盘策略:

建议设置为 2(性能与安全的折中),可减少主从 IO 延迟 。
sync_binlog0, 1, N控制 Binlog 的同步策略:

建议设置为 1000(或类似值),可减少主从 IO 延迟,但需接受一定数据丢失风险 。

3、 调整从库配置

4、避免大事务

5、使用PT工具执行耗时较长的DDL

6、调整架构

http://www.lryc.cn/news/592826.html

相关文章:

  • 亚马逊新手如何快速上手广告运营,实现品牌曝光与销量提升?
  • Springboot3整合Elasticsearch8(elasticsearch-java)
  • Overleaf撰写文档
  • kubernetes pod 深度解析
  • Entity Framework (EF) 深度解析
  • 荷兰KIPP ZONEN CMP4 太阳辐射传感器耐热仪器设计高温日射计一种辐射计
  • CH347 USB高速编程器烧录器
  • 菱形继承 虚继承
  • Java学习------ConcurrentHashMap
  • 外部DLL创建及使用
  • react控制react Popover组件显示隐藏
  • Agent AI(3):Agent分类
  • Jenkins pipeline 部署docker通用模板
  • 网关-微服务网关入门
  • 《Qt数据库》知识点实践
  • VisualXML全新升级 | 新增BusLoad计算
  • 在 OpenSUSE Tumbleweed 和 Leap 上安装 VirtualBox
  • ChatGPT Agent:统一端到端Agentic模型的技术革新与行业影响
  • Sui 在非洲增长最快的科技市场开设 SuiHub Lagos 以推动创新
  • 质变科技亮相可信数据库发展大会,参编《数据库发展研究报告2025》
  • 读书笔记:《动手做AI Agent》
  • 飞算科技:以创新科技引领数字化变革,旗下飞算 JavaAI 成开发利器
  • 软件工程中的《资本论》
  • KRaft 角色状态设计模式:从状态理解 Raft
  • Redis学习其二(事务,SpringBoot整合,持久化RDB和AOF)
  • java基础——面向对象04(继承)
  • 通俗易懂:什么是决策树?
  • STM32-第七节-TIM定时器-3(输入捕获)
  • STL—— list迭代器封装的底层讲解
  • 小白学Python,网络爬虫篇(2)——selenium库