一、预先需要了解的知识
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在内存的中位置了。
相关推荐:
SEO策划:让你的网站迅速脱颖而出的秘诀,seo优化和技巧
SEO优化全攻略提升网站排名的关键步骤与未来趋势,这是什么新晋动画ai
ChatGPT怎么突然不能打开了?你需要了解的原因与解决办法,ai写作有什么问题吗怎么解决
怎么查一篇文章是不是AI写的?你需要这几个关键方法!
为什么seo吸引人,为什么seo吸引人呢 ,ai路径查找器绘制树
一键创作,助你轻松实现创意梦想,最低价刷粉网站推广
seo算是什么营销方式,seo是网络营销吗 ,ai318
SEO攻略:搜索引擎优化,快速提升网站排名,网站推广网站优化费用
SEO实现:如何通过SEO优化提升网站流量与排名,南京市公司网站推广
ChatGPT维护页面-背后的技术与用户体验,ai领域ppt
seo适合什么人做,哪种seo做得好 ,晋城ai论文写作免费
SEO做网站点击:提升网站流量的关键策略,国内ai写作论文
ChatGPT内部HTTP接口文档-为开发者提供高效便捷的AI服务接入方式,安屿ai
SEO架构:提升网站流量的核心策略,东营南江全平台营销推广
SEO教研:数字营销新趋势,提升网站流量与转化率的关键,齐鲁证券网站建设
seo资源指的是什么,seo资料 ,绿眼AI
怎样利用AI写文章,轻松提升写作效率
SEO门户:打造高效网站流量的关键利器,创意网站建设要求
SEO要不,来看看如何通过SEO优化提高网站流量和曝光度,seo 获客技巧
AI工具汇总网站,让科技为您的工作加速
SEO排位:如何通过精准策略提升网站排名,获得流量与转化,林海网络推广营销
ChatGPTDNS出问题?如何快速解决并保障网络畅通,墨镜ai照片
WP原创:打造属于你的独特网站,从这里开始!,一个网站推广一个月需要多少钱
seo用什么论坛引流,seo引流方法 ,ai写作续写神器
在线AI写文:开启高效创作新时代
WPJVX:开启数字化未来的智慧平台,关键词排名技术咨询乐云seo
文章AI扩写:突破创作瓶颈,提升写作效率的秘密武器
seo要懂些什么,seo主要做什么的 ,小艾艾AI
ChatGPT恢复正常使用时间,提升你的工作与生活效率,联想电脑AI0510
seo需要懂什么源码,seo需要懂什么源码技术 ,ai 纤维
《权重参谋:让您的网站轻松登顶搜索引擎的秘密武器》,设计微信社群私域营销推广简案
SEO元素-提升网站排名的核心要素,推广分成网站有哪些
SEO外,如何提升网站整体营销效果?,文轩网络营销推广方案
AI人工智能:开发与应用的必备软件推荐
优化标题:如何让你的文章更具吸引力与点击力,整站网站优化解决方案
SEO有点:揭秘优化之道,提升网站排名的秘诀,广州抖音seo厂家地址
SEO地位:如何提升你的网站排名与曝光度,抢占市场先机,微营销网络推广
SEO目标:让您的网站轻松登顶搜索引擎,优化购物网站的搜索
ChatGPT出问题?背后的原因与解决方案,夸克ai写作生成
Chato1免费么?揭开这款AI聊天机器人的神秘面纱,交个朋友ai写作
SEO优化10种策略:提升网站排名的有效方法,帅气ai男头白底
SEO大神如何在激烈的互联网竞争中脱颖而出?,网页设计和网站建设试题
目前国内最好的AI人工智能软件:未来新篇章
SEO小白必看!从零起步SEO的秘诀,轻松提升网站排名,南京网站运营优化平台
SEO全套秘籍:提升网站流量与排名的终极指南,荣昌手机网站建设
乘风SEO:突破困境,领航网络营销新时代,武汉靠谱的关键词排名
ChatGPT页面无法翻阅?带你深度了解背后的原因与解决方案,pdf怎么转换ai文字
ChatGPT页面无法下拉?禁用浏览器扩展,轻松解决!,imba 1.6 ai
seo需要学习什么语言,做seo需要懂什么技术 ,ai软件制作教程
SEO课:让你从小白变成搜索引擎优化高手,推广自媒体营销计划