大家好,今日小天来为大家解答以上的问题。redis查看数据,redis查看数据库大小很多人还不知道,现在让我们一起来看看吧!

redis查看数据 redis查看数据库大小redis查看数据 redis查看数据库大小


redis查看数据 redis查看数据库大小


1、typedef struct dict {博客地址: 一、预先需要了解的知识 1、redis 中的每一个数据库,都由一个 redisDb 的结构存储。

2、其中,redisDb.id 存储着 redis 数据库以整数表示的号码。

3、redisDb.dict 存储着该库所有的键对数据。

4、red示例:博客地址:一、预先需要了解的知识1、redis 中的每一个数据库,都由一个 redisDb 的结构存储。

5、其中,redisDb.id 存储着 redis 数据库以整数表示的号码。

6、redisDb.dict 存储着该库所有的键值对数据。

7、redisDb.expires 保存着每一个键的过期时间。

8、2、当redis 初始化时,会预先分配 16 个数据库(该数量可以通过配置文件配置),所有数据库保存到结构 redis 的一个成员 redis.db 数组中。

9、当我们选择数据库 select number 时,程序直接通过 redis.db[number] 来切换数据库。

10、有时候当程序需要知道自己是在哪个数据库时,直接读取 redisDb.id 即可。

11、// 特定于类型的处理函数dictType type;// 类型处理函数的私有数据// 哈希表(2个)dictht ht[2];// 记录 rehash 进度的标志,值为-1 表示 rehash 未进行int rehashidx;// 当前正在运作的安全迭代器数量int iterators;} dict;由上述的结构可以看出,redis 的字典使用哈希表作为其底层实现。

12、dict 类型使用的两个指向哈希表的指针,其中 0 号哈希表(ht[0])主要用于存储数据库的所有键值,而1号哈希表主要用于程序对 0 号哈希表进行 rehash 时使用,rehash 一般是在添加新值时会触发,这里不做过多的赘述。

13、所以redis 中查找一个key,其实就是对进行该dict 结构中的 ht[0] 进行查找作。

14、4、既然是哈希,那么我们知道就会有哈希碰撞,那么当多个键哈希之后为同一个值怎么办呢?redis采取链表的方式来存储多个哈希碰撞的键。

15、也就是说,当根据key的哈希值找到该列表后,如果列表的长度大于1,那么我们需要遍历该链表来找到我们所查找的key。

16、当然,一般情况下链表长度都为是1,所以时间复杂度可看作o(1)。

17、二、当redis 拿到一个key 时,如果找到该key的位置。

18、了解了上述知识之后,我们就可以来分析redis如果在内存找到一个key了。

19、1、当拿到一个key后, redis 先判断当前库的0号哈希表是否为空,即:if (dict->ht[0].size == 0)。

20、如果为true直接返回NULL。

21、2、判断该0号哈希表是否需要rehash,因为如果在进行rehash,那么两个表中者有可能存储该key。

本文到这结束,希望上面文章对大家有所帮助。