redis中KEYS、SMEMBERS、SCAN 、SSCAN 的区别

今天在看项目中大神写的框架中关于redis存储相关代码时,发现了再获取set数据类型的全部元素时,采用的是sscan函数,而不是采用的smembers函数,这两个到底有什么区别呢?

先看这两个命令:

keys:用于获取当前数据库的模式匹配的所有key

smembers:获取set集合中的所有元素

而scan又包含多个类似命令

SCAN 增量迭代当前数据库中的数据库键。
SSCAN 增量迭代集合键中的元素。
HSCAN 增量迭代哈希键中的键值对。
ZSCAN 增量迭代有序集合中的元素(包括元素成员和元素分值)。
也就是说,keys、smembers和scan家族命令的最大区别是:

          keys和smembers是获取全部,如果当redis中key的数量过去庞大(或者set的元素很多),则很耗费内存,会阻塞redis几秒钟

         scan家族是逐步增量获取。即遍历获取一定数量的key或者元素,在获取一定数量的key或元素,不会一次获取。

那么,scan命令就比keys、smembers命令好吗?不是这样的,scan命令家族也是有缺点的。由于scan采用的增量迭代,当redis中的key是随时变化的,比如key增加减少或者key的名字变更,这种情况,scan就暴露他的弊端了,可能无法获取所有的key了。

所以采用哪种方式获取key或者获取元素,得根据自己的业务,如果你key是随时变化,就采用keys或者smembers吧。因为我们业务中redis的初始化只是在项目启动时初始化一次,所以在获取set的全部元素时采用的sscan命令。

posted @ 2020-03-15 10:51  那些年的代码  阅读(2073)  评论(0编辑  收藏  举报