栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Redis 内存占满导致的 Setnx 命令执行失败

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Redis 内存占满导致的 Setnx 命令执行失败

一、问题发生

正常情况下,通过 setnx 设置的一个锁,应该会1s后过期(防止并发请求,处理相同逻辑),但是实际发生的情况是,第一次处理下面的逻辑,就抛出异常。说明 setnx 函数返回了 false。

$redis_key_lock = 'lock'; 

//@todo 设置了一个1s的锁
$lock           = $redis->setnx($redis_key_lock, 1);

//@todo 锁将会在1s后过期
$redis->expire($redis_key_lock, 1);

if ($lock) {
    // 执行其他逻辑
} else {
    throw new Exception("锁存在");
}

二、问题排查

redis 的内存占用满了

通过 redis.conf 查看一下 redis 过期策略

# maxmemory-policy volatile-lru

说明 redis 使用了默认的过期策略 noeviction

默认的过期策略 noeviction 不会对过期的 keys 做任何清理,当内存占用满后,会拒绝执行所有的写操作,通过翻阅redis配置文件,可以查到相关提示,并且除了 setnx,其他的写操作相关指令,都会执行失败。

 解决方案就是快速释放 redis 内存,让 setnx 命令可以正常执行。

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/826982.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号