数据库
首页 > 数据库> > Redis 优雅删除BigKey

Redis 优雅删除BigKey

作者:互联网

危害

如何发现

注:serializedlength 不代表真实的字节大小,返回的是对象使用 RDB 编码序列化后的长度,值会偏小。但对排查 bigkey 有一定辅助作用,因为并不是每种数据类型都支持 strlen 的方法。

实际生产环境发现 bigkey 的两种方式:

开发提醒:

如何删除

如发现 bigkey 后,无论什么命令,最都可直接使用 del 将其删除。但实际情况并非如此,不同的数据类型,不同的元素个数等不尽相同,删除可能会造成 redis 阻塞。

耗时对比

删除字符串类型,不同大小的耗时对比:

key 类型512KB1MB2MB5MB10MB
string0.22ms0.31ms0.32ms0.56ms1ms

总结:string 类型随着 value 值的不断增大,删除速度也逐渐减慢。

删除 hash、list、set、sorted set 四种数据类型,不同数量,不同元素大小的耗时对比:

key 类型10W (8个字节)100W (8个字节)10W (16个字节)100W (16个字节)10W (128个字节)100W (128个字节)
hash51ms950ms58ms970ms96ms2000ms
list23ms134ms23ms138ms23ms266ms
set44ms873ms58ms881ms73ms1319ms
sorted set51ms845ms57ms859ms59ms969ms

总结:非字符串类型,元素的个数越多,元素越大,删除时间越长。且该删除时间,足够引起 Redis 阻塞。

如何优雅删除

如何优雅的删除,且不影响 Redis 阻塞?相关 scan 命令如:sscanhscanzscan

最佳实践

 

标签:字节,删除,bigkey,Redis,阻塞,优雅,BigKey,key
来源: https://blog.csdn.net/wmq880204/article/details/116429986