Welcome 微信登录

首页 / 操作系统 / Linux / Redis 曝新 BUG:内存超限后的死循环

Redis曝出了一个新bug,如果你设定了Redis的maxmemory,并且这个Redis有Slave,那么当你的maxmemory限制达到后,就会出现死循环。具体原因和流程如下:
  • Redis 达到了配置中设定的maxmemory限制,开始按LRU策略删除数据
  • 被过期清除的数据会生成DEL 日志推送到Slave
  • 但是如果Slave达到一定数量时,这条DEL日志使用的output buffer空间可能会超过刚刚清除数据空闲出来的空间,这时候会导致空间又超限了
  • 于是整个清除过程就变成了死循环
而且这个问题不仅会出现在Slave的情况下,在写AOF buffer的时候也会发生同样的问题。Redis作者随后发布了补丁(This fixes issue)对这个问题进行修复。目前此bug的修复已经合并到2.4的主干中,截止目前为止,Redis官方2.4.8稳定版本中已经包含对此问题的修复。问题地址:issues #327Linux 命令行终极挑战Gentoo Linux下查看工作组网络时提示:Nautilus cannot handle “smb” locations.相关资讯      Redis 
  • Redis 非关系型数据库 ( Nosql )  (07月01日)
  • Java中使用Jedis操作Redis  (04月08日)
  • 在Ubuntu 14.04下安装Redis  (01月31日)
  • 关于 Redis的订阅发布  (04月15日)
  • MongoDB仲裁节点的理解及Memcached  (02月13日)
  • 关于redis中的Replication  (01月29日)
本文评论 查看全部评论 (0)
表情: 姓名: 字数