REDIS中意外的耗时命令-DEL-EXISTS

在排查Redis耗时的过程中发现大量的EXISTS命令耗时很长。很意外,印象中感觉这个这个命令应该是很快执行完的。随后了解到

1. Redis中DEL命令的时间复杂度对于字符串和哈希值而言是O(1),而对于list、set和sorted set而言则是O(N) (这里的 N 是集合中数据项的数目)。所以对于大集合key,DEL命令会很耗时。

2. 在EXISTS命令处理函数中实现了清除过期key的主动策略,会先调用 expireIfNeeded 函数检查要访问的 key 是否过期,如果过期就delete掉这个key。所以对于大集合,EXISTS命令也有可能会很耗时。




  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值