首页 游戏 软件 资讯 排行榜 专题
首页
数据库
Redis主从复制数据同步性能瓶颈_排查主库磁盘IO与从库网络带宽

Redis主从复制数据同步性能瓶颈_排查主库磁盘IO与从库网络带宽

热心网友
78
转载
2026-04-26

Redis主从同步性能瓶颈排查:当全量同步“卡”住时,你在看哪里?

Redis主从复制数据同步性能瓶颈_排查主库磁盘IO与从库网络带宽

免费影视、动漫、音乐、游戏、小说资源长期稳定更新! 👉 点此立即查看 👈

主库 bgsa ve 卡住,其实是磁盘 IO 被拖垮了

遇到全量同步慢,第一反应往往是“网络不行”。但真相是,当问题卡在主库的 bgsa ve 阶段时,十有八九不是CPU算力不足,而是磁盘的写入速度彻底跟不上了。尤其是在使用机械硬盘、云盘IOPS被限速,或者RDB文件过大(比如超过2GB)的场景下,bgsa ve 子进程会长时间阻塞,导致主线程的复制缓冲区持续积压,最终触发从库重试,形成一个恶性循环。

  • redis-cli --stat 实时观察:如果看到 bgsa ve_in_progress:1 状态持续超过30秒,同时 used_memory_human 突然增长、latest_fork_usec 大于500000(即500毫秒),基本可以断定是fork和写盘遇到了双重瓶颈。
  • 查磁盘真实压力:运行 iostat -x 1 3,关注 %util 是否长期高于90%,以及 await 是否大于50ms。在云环境下,要特别留意EBS或云盘的IOPS配额是否已经用尽。
  • 解决思路:临时方案是停掉自动RDB保存(执行 CONFIG SET sa ve ""),改用AOF并设置 appendfsync everysec。长期根治则需要迁移到SSD硬盘、升级云盘配置,或者考虑拆分大实例。

从库加载 RDB 慢,别只盯 CPU,先看网络吞吐是否被限死

从节点上执行 INFO replication,如果显示 master_sync_in_progress:1 状态持续很久,但 master_sync_left_bytes 下降得极其缓慢(比如每秒只减少几MB),那就说明RDB文件压根没“流”进来——问题不在于从库解析数据的能力,而在于主库发不出来,或者中间的传输链路被卡住了。

  • 确认主库是否真在发数据:在主节点上使用 ss -itcpdump -i any port 6379 抓包,观察是否有持续的大块TCP数据包(大于1MB)发出。如果没有,问题就出在主库的发送环节。
  • 检查 client-output-buffer-limit sla ve 配置:如果这个值设成了 256mb 64mb 60,而RDB文件有4GB,传输需要200秒,那么在60秒内累计超过64MB,主节点就会强制断开连接,导致从库反复重试全量同步。
  • 生产环境建议:直接将其设置为 1024mb 512mb 60。同时,确保从库的网卡和交换机端口没有被限速,尤其是在跨机房场景下,TCP窗口缩放、MTU不匹配等问题都可能导致网络吞吐量骤降。

repl-backlog-size 设小了,表面是同步慢,实际是被迫反复全量

从节点断线重连后,没有走增量同步(PSYNC),而是直接回退到全量同步(SYNC)。这往往不是因为网络断开太久,而是因为主节点的复制积压缓冲区太小,旧的复制偏移量(offset)对应的数据早就被新数据覆盖了。这会让一个本该毫秒级恢复的同步,变成耗时数分钟的RDB重传。

  • 估算公式必须带余量repl-backlog-size = QPS × a vg_cmd_size × max_reconnect_time × 1.5。举个例子,如果写入QPS是3000,平均命令大小是180B,要求能容忍180秒的断连,那么至少需要145MB的缓冲区。但在生产环境中,建议直接从512MB起步,甚至设为 1024mb
  • 理解缓冲区特性repl-backlog-size 是一个环形缓冲区,设置得大一些并不会占用常驻内存,只在有写流量时动态分配。相反,如果设小了,会引发雪球效应:一次全量同步失败,会导致更多从库排队等待RDB,进而给主库带来更大压力,使得从库更容易断连。
  • 验证配置是否生效:通过 CONFIG GET repl-backlog-sizeINFO replication 命令,检查 repl_backlog_active(应为1)和 repl_backlog_size(应与配置值一致)。

diskless sync 开启后反而更慢?那是没关 THP

启用 repl-diskless-sync yes 的本意是跳过主库落盘,直接通过socket发送RDB数据。但如果操作系统开启了透明大页(THP),在fork子进程时,会将整个Redis内存按2MB的大页单位进行拷贝,导致 latest_fork_usec 暴涨到数秒,反而比落盘到磁盘还要慢。

  • 立刻检查并关闭THP:运行 cat /sys/kernel/mm/transparent_hugepage/enabled,如果输出包含 [always],必须关闭它:echo never > /sys/kernel/mm/transparent_hugepage/enabled
  • diskless sync 的真正受益场景是:主库磁盘性能极差,但网络条件非常好(比如万兆同机架)。否则,保持 repl-diskless-sync no,让bgsa ve异步写盘,往往更可控。
  • 开启diskless后的必要配合:务必设置 repl-diskless-sync-delay(建议5~10秒),为子进程的fork操作留出时间,避免因并发连接激增导致fork失败。

最后,还有一个最容易被忽略的底层因素:以上所有调优,都必须建立在一个基础上——主从节点之间的系统时间必须同步。记得用 ntpq -p 检查一下时间偏移量。

来源:https://www.php.cn/faq/2310254.html
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

相关攻略

台铃电车如何锁车不耗电?
电脑教程
台铃电车如何锁车不耗电?

台铃电动车锁车,真的不耗电吗? 关于电动车锁车后是否还在“偷偷”用电,很多用户心里都有个问号。答案很明确:台铃电动车的锁车状态本身,几乎不产生额外电量消耗。其核心在于一套精心设计的电子防盗系统,在锁止后,整车的主供电电路会被立刻切断,只留下防盗模块、钥匙信号接收器等核心安防单元,以极低的功耗维持待命

热心网友
04.25
老年助听器怎么安装后能用吗?
电脑教程
老年助听器怎么安装后能用吗?

老年助听器怎么安装后能用吗? 开门见山地说,给长辈选配助听器,可千万别把它当成“即插即用”的普通电子产品。这本质上是一套严谨的医疗康复流程,核心在于“专业验配”与“科学适应”。没有这两步,再好的设备也可能沦为抽屉里的闲置品。 真正的效能发挥,始于一份精准的听力“地图”——通过纯音测听、声导抗等医学检

热心网友
04.25
高考前冲刺口号
礼仪与书信
高考前冲刺口号

高考前冲刺口号 话说回来,每年到了这个时节,教室里、走廊上、甚至学生的课桌一角,总能看到一些凝聚着决心与期盼的句子。它们不仅仅是口号,更像是一股无声的力量,在最后关头为学子们注入信念。下面这份汇集了多年备考智慧的清单,或许能为你带来一些启发。 信念与心态篇 1 Everything is poss

热心网友
04.25
高中励志口号
礼仪与书信
高中励志口号

班风口号:胜不骄,败不馁,有志不在年高,但求力争上游 “胜不骄,败不馁”这六个字,分量可不轻。它源自《商君书·战法》,原话是“王者之兵,胜而不骄,败而不怨。”这提醒我们,成功时别让骄傲蒙了眼,失败时也别被沮丧拖垮了脚。保持清醒与韧性,才是长久之道。 紧接着的“有志不在年高”,出自《封神演义》。这话说

热心网友
04.25
下学期中班孩子评语
礼仪与书信
下学期中班孩子评语

下学期中班孩子评语1 1、 这孩子聪明又活泼,课堂上总能看到他高高举起的小手,思维活跃得很,发言特别踊跃。做数学题又快又准,小脑袋转得飞快,语言表达能力也强,还经常主动上来给大家讲故事。要是以后能加强小手的锻炼,让它变得更灵巧,那就更棒了,咱们一起朝着心灵手巧的目标加油吧! 2、 小家伙的口才真不错

热心网友
04.25

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

虚拟键盘怎么用键盘打字不冲突?
电脑教程
虚拟键盘怎么用键盘打字不冲突?

虚拟键盘与物理键盘可以完全协同工作,互不干扰 你可能会好奇,一个在屏幕上,一个在桌面上,它们俩同时用起来,会不会“打架”?答案是:完全不会。这背后的核心,其实是一套非常成熟的系统级输入法管理机制在起作用。简单来说,当你连接了外接键盘,系统默认会让虚拟键盘进入“休眠”状态;而一旦你通过触控屏幕或者按下

热心网友
04.26
博世壁挂炉怎么单独用生活用水
电脑教程
博世壁挂炉怎么单独用生活用水

博世壁挂炉完全支持仅启用生活热水功能,无需同步开启采暖系统 想让家里的博世壁挂炉只出热水、不启动暖气?这事儿其实很简单。用户可以直接通过控制面板上的“水龙头键”一键切入生活热水模式,或者长按“模式”键进入菜单,选择专属的热水运行状态。部分带旋钮的型号,操作更直观,只需将旋钮转到“*”档或“min”位

热心网友
04.26
小米智能手表时间怎么调时间显示错误
电脑教程
小米智能手表时间怎么调时间显示错误

小米智能手表时间校准全指南:从自动同步到手动精调 你的小米智能手表时间不准了?别急着重启,更别怀疑手表坏了。其实,它的时间默认是通过蓝牙与配对手机自动同步的,整个过程在后台静默完成,无需你动手,就能保持高精度授时。这套机制背后,是NTP网络时间协议与小米Wear应用的协同调度,不仅支持毫秒级校准,还

热心网友
04.26
小米note3铃声音量调不了怎么办?
电脑教程
小米note3铃声音量调不了怎么办?

小米Note 3铃声音量调节失灵?别急,这是份系统化的排查指南 遇到小米Note 3的铃声音量键失灵,先别急着下结论是硬件坏了。这背后,往往是软件逻辑的临时“卡壳”、系统设置的细微偏移,或是物理按键通路受阻共同作用的结果。从官方维修渠道的反馈来看,大约六成用户的问题,根源在于系统缓存的临时堆积或第三

热心网友
04.26
小米音响怎么蓝牙配对电脑
电脑教程
小米音响怎么蓝牙配对电脑

小米音响蓝牙配对电脑:三步搞定,实测稳定 想把小米音响变成电脑的得力外放?其实很简单,整个过程三步就能走完:打开音箱蓝牙、启动电脑蓝牙搜索、在列表里找到它点连接。根据小米官方的指南,再结合Windows 11和macOS系统的实际测试,像Xiaomi Sound、Xiaomi Sound Pro这些

热心网友
04.26