zoukankan      html  css  js  c++  java
  • 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命令。

  • 相关阅读:
    数据不平衡
    2D到3D 外参矩阵估计
    ppt 绘图转成 Latex 常用的 eps 格式
    3D 旋转中 旋转矩阵 欧拉角 四元数的相互转换
    opencv使用 --- fastGlobalSmootherFilter
    Pytorch
    MTCNN 复现
    3DFace基础---光照估计
    Pytorch --- cuda 相关
    Pytorch---多维数组运算过程的索引处理
  • 原文地址:https://www.cnblogs.com/zhuyeshen/p/12496406.html
Copyright © 2011-2022 走看看