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命令。

  • 相关阅读:
    行列式运算法则
    神经元的数学模型
    Neural Network and Artificial Neural Network
    常见的23种设计模式
    Java 基本数据类型 及 == 与 equals 方法的区别
    MySQL经典编程问题
    MyEclipse配置tomcat报错
    MySQL 日期类型函数及使用
    MySQL dump文件导入
    MySQL 的两个特殊属性 unsigned与 zerofill
  • 原文地址:https://www.cnblogs.com/zhuyeshen/p/12496406.html
Copyright © 2011-2022 走看看