首页 > 其他 > 详细

redis阻塞bgsave与bsrewriteaof

时间:2017-06-06 00:52:18      阅读:491      评论:0      收藏:0      [点我收藏+]

问题描述:

        redis在进程偶尔会出现2个进程redis-server \ redis-bgsave

Redis 首先 fork 一个子进程, 并在该子进程里进行归并和写持久化存储设备(如硬盘)的. 按照正常逻辑, 在一台多核的机器上, 即使子进程占满 CPU 和硬盘, 也不应该导致 Redis 服务阻塞啊!其实, 问题就出在硬盘上.

  Redis 服务设置了appendfsync everysec, 主进程每秒钟便会调用 fsync(), 要求内核将数据”确实”写到存储硬件里. 但由于子进程同时也在写硬盘, 从而导致主进程 fsync()/write() 操作被阻塞, 最终导致 Redis 主进程阻塞了.

解决方法:

no-appendfsync-on-rewrite yes

在子进程处理和写硬盘时, 主进程不调用 fsync() 操作. 注意, 即使进程不调用 fsync(), 系统内核也会根据自己的算法在适当的时机将数据写到硬盘(Linux 默认最长不超过 30 秒).

redis阻塞bgsave与bsrewriteaof

原文:http://www.cnblogs.com/xiaochina/p/6288717.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!