如果redis中放入多个数据库表,怎么区分

 我来答
公羊学岺碧胭
2019-08-18 · TA获得超过3.5万个赞
知道大有可为答主
回答量:1.2万
采纳率:31%
帮助的人:2184万
展开全部
1、redis
中的每一个数据库,都由一个
redisDb
的结构存储。其中,redisDb.id
存储着
redis
数据库以整数表示的号码。redisDb.dict
存储着该库所有的键值对数据。redisDb.expires
保存着每一个键的过期时间。
2、当redis
服务器初始化时,会预先分配
16
个数据库(该数量可以通过
配置文件
配置),所有数据库保存到结构
redisServer
的一个成员
redisServer.db
数组中。当我们选择数据库
select
number
时,程序直接通过
redisServer.db[number]
来切换数据库。有时候当程序需要知道自己是在哪个数据库时,直接读取
redisDb.id
即可。
余若谷夙棋
2019-12-01 · TA获得超过3.5万个赞
知道大有可为答主
回答量:1.2万
采纳率:33%
帮助的人:961万
展开全部
1、redis
中的每一个数据库,都由一个
redisdb
的结构存储。其中,redisdb.id
存储着
redis
数据库以整数表示的号码。redisdb.dict
存储着该库所有的键值对数据。redisdb.expires
保存着每一个键的过期时间。
2、当redis
服务器初始化时,会预先分配
16
个数据库(该数量可以通过配置文件配置),所有数据库保存到结构
redisserver
的一个成员
redisserver.db
数组中。当我们选择数据库
select
number
时,程序直接通过
redisserver.db[number]
来切换数据库。有时候当程序需要知道自己是在哪个数据库时,直接读取
redisdb.id
即可。
3、既然我们知道一个数据库的所有键值都存储在redisdb.dict中,那么我们要知道如果找到key的位置,就有必要了解一下dict
的结构了:
typedef
struct
dict
{
//
特定于类型的处理函数
dicttype
*type;
//
类型处理函数的私有数据
void
*privdata;
//
哈希表(2个)
dictht
ht[2];
//
记录
rehash
进度的标志,值为-1
表示
rehash
未进行
int
rehashidx;
//
当前正在运作的安全迭代器数量
int
iterators;
}
dict;
由上述的结构可以看出,redis
的字典使用哈希表作为其底层实现。dict
类型使用的两个指向哈希表的指针,其中
0
号哈希表(ht[0])主要用于存储数据库的所有键值,而1号哈希表主要用于程序对
0
号哈希表进行
rehash
时使用,rehash
一般是在添加新值时会触发,这里不做过多的赘述。所以redis
中查找一个key,其实就是对进行该dict
结构中的
ht[0]
进行查找操作。
4、既然是哈希,那么我们知道就会有哈希碰撞,那么当多个键哈希之后为同一个值怎么办呢?redis采取链表的方式来存储多个哈希碰撞的键。也就是说,当根据key的哈希值找到该列表后,如果列表的长度大于1,那么我们需要遍历该链表来找到我们所查找的key。当然,一般情况下链表长度都为是1,所以时间复杂度可看作o(1)。
二、当redis
拿到一个key
时,如果找到该key的位置。
了解了上述知识之后,我们就可以来分析redis如果在内存找到一个key了。
1、当拿到一个key后,
redis
先判断当前库的0号哈希表是否为空,即:if
(dict->ht[0].size
==
0)。如果为true直接返回null。
2、判断该0号哈希表是否需要rehash,因为如果在进行rehash,那么两个表中者有可能存储该key。如果正在进行rehash,将调用一次_dictrehashstep方法,_dictrehashstep
用于对数据库字典、以及哈希键的字典进行被动
rehash,这里不作赘述。
3、计算哈希表,根据当前字典与key进行哈希值的计算。
4、根据哈希值与当前字典计算哈希表的索引值。
5、根据索引值在哈希表中取出链表,遍历该链表找到key的位置。一般情况,该链表长度为1。
6、当
ht[0]
查找完了之后,再进行了次rehash判断,如果未在rehashing,则直接结束,否则对ht[1]重复345步骤。
到此我们就找到了key在内存中的位置了。
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式