您当前的位置:首页 > 电脑百科 > 数据库 > Redis

Redis快的秘诀

时间:2019-07-29 11:34:22  来源:  作者:

导读:redis是一个高性能的key-value数据库,在实际开发中常被用于做分布式缓存、消息队列等。Redis如此受欢迎这其中一个重要原因是因为其读写数据速度快,能支持10w+qps(每秒查询率)。那么Redis快的原因是什么?文本从以下三点展开讨论

  • 数据存到内存
  • 采用单线程模型
  • 使用多路I/O复用的I/O模型
Redis快的秘诀

 

1、数据存到内存

Redis数据存在内存中且绝大部分请求是对内存操作,因此在进行读写数据操作的时候不会受到硬盘 I/O 速度的限制,速度快。

补充:Redis也提供了两种数据持久化方式:AOF(可回放的命令日志)与 RDB(内存快照)。两种持久化方式各有优缺点,从Redis4.0开始允许使用RDB-AOF混合持久化的方式,这种方式结合了两者的优点。这里本文不做具体讨论。

2、采用单线程模型

2.1 文件事件处理器

Redis 服务器是一个事件驱动程序, 处理的事件分为时间事件和文件事件。Redis基于reactor设计模式开发了文件事件处理器用于高效地处理事件。

它的组成结构为4部分:多个套接字(socket)、IO多路复用程序、文件事件分派器、事件处理器(如下图所示)。因为这个文件处理器是单线程的,所以Redis是单线程模型。

Redis快的秘诀

文件事件处理器

2.2单线程模型的优点

通过采用单线程避免了多线程中的上下文切换损耗及不需要考虑锁问题以及锁问题带来的损耗等。

补充:Redis对数据事件的处理是单线程的,但它在其他模块仍用了多个线程,如异步将数据写入磁盘进行持久化操作。

3、使用多路I/O复用的I/O模型

3.1 概念介绍

I/O模型分为以下五种:

  • 同步阻塞I/O
  • 同步非阻塞I/O
  • IO多路复用(Reactor设计模式也称为异步阻塞IO,例子:JAVA的Selector、linux的epoll)
  • 信号驱动I/O模型
  • 异步非阻塞I/O(Proactor设计模式)

在“Redis使用多路I/O复用模型”中“多路”指的是多个Socket连接,“复用”指的是复用同一个线程。采用多路 I/O 复用技术可以让单个线程高效的处理多个连接请求。 (关于I/O模型的讲解将会在以后的文章里做详细讨论,感兴趣的朋友欢迎后续阅读与讨论)

Redis快的秘诀

 

3.2 I/O多路复用模型在Redis中的应用

Redis使用epoll同时监听多个Socket连接,并给不同Socket关联不同的处理程序。当被监听的Sokcet准备好连接应答、请求、应答、关闭等操作时,就会产生对应的文件事件。这时文件事件处理器就会调用Socket之前关联好的事件处理器来处理这些事件。

4.总结

Redis之所以快其中主要三个原因为:数据存到内存、采用单线程模型避免了些不必要的损耗、使用多路I/O复用的I/O模型让单个线程高效的处理多个连接请求。快也还有包括其他的原因如数据模型等。



Tags:   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
前言什么是数据脱敏数据脱敏是指对某些敏感信息通过脱敏规则进行数据的变形,实现敏感隐私数据的可靠保护常用脱敏规则替换、重排、加密、截断、掩码良好的数据脱敏实施1、尽...【详细内容】
2021-12-28  Tags: Redis  点击:(3)  评论:(0)  加入收藏
河南最有名的“13碗面”,吃过10种以上的一定是地道河南人,你吃过几碗?河南位于黄河中下游,优越的地理位置和条件,让河南的种植业在全国脱颖而出,被称为全国的“粮仓”。小麦是河南...【详细内容】
2021-12-28  Tags: Redis  点击:(3)  评论:(0)  加入收藏
在狗界中,有些狗狗比较凶残、霸道,今天我们就来说说被称为“犬中四煞”的4种狗,请认住它们的长相,看见了要绕路走! NO1:黑狼犬产地:中国寿命:11-12年黑狼犬是狼狗的一种,长大高大威猛...【详细内容】
2021-12-28  Tags: Redis  点击:(3)  评论:(0)  加入收藏
协议下的体面离婚 2015年1月 方晴供职于一家外企,袁亮硕士毕业后开了家公司。两人相识、恋爱后走进婚姻殿堂。 方晴和袁亮的儿子小浩出生了。本该是其乐融融的三口之家,却在一...【详细内容】
2021-12-28  Tags: Redis  点击:(2)  评论:(0)  加入收藏
中国人神话世界五千年到一万年之前到底是一个什么样的世界?相信这个问题应该是困扰了大家许久吧!其实这些问题可以从远古时代的三皇五帝开始说起,三皇五帝对于中国人的影响就如...【详细内容】
2021-12-28  Tags: Redis  点击:(2)  评论:(0)  加入收藏
去年有个新闻,说的是一名印度女孩自小被欧洲有钱人家收养,长大后要回来给自己出生的村子捐钱做慈善。等她回村的时候,村里人专门为女孩修了一条路。表面上看,这貌似是个暖心的故...【详细内容】
2021-12-28  Tags: Redis  点击:(3)  评论:(0)  加入收藏
日本在今年又给大家带来了一个巨大消息,日本著名的球星本田圭佑出资设立的一家公司,正式发售了飞行摩托车。 在之前可是在电视或者是电影中才能看到的,是具备了未来科幻的一个...【详细内容】
2021-12-28  Tags: Redis  点击:(4)  评论:(0)  加入收藏
V社今日公布了2021年Steam最畅销游戏榜单,其中涵盖了本年度Steam上收入最高的100款游戏。为了得出每款游戏的总收入,Steam计算了2021年1月1日至2021年12月15日的游戏销售额、...【详细内容】
2021-12-28  Tags: Redis  点击:(3)  评论:(0)  加入收藏
“都怪我一时糊涂铸下大错,这几年为了蒙混过关,拆东墙补西墙就怕被发现,我对不起信任我的领导同事,更对不起我的家人。”内蒙古某国有合资公司原出纳员包某在庭审现场听取公诉人...【详细内容】
2021-12-28  Tags: Redis  点击:(2)  评论:(0)  加入收藏
2021年黄金价格下跌11.3%,黄金现在已经下跌了6.5%。白银价格一度下跌19.3%,白银现在已经下跌了15%。美元通胀。白银自2020年2月份以来,五家中央银行(Fed、欧洲中央银行、日本中...【详细内容】
2021-12-28  Tags: Redis  点击:(3)  评论:(0)  加入收藏
▌简易百科推荐
来源: my.oschina.net/xiaomu0082/blog/2990388首先说下问题现象:内网sandbox环境API持续1周出现应用卡死,所有api无响应现象刚开始当测试抱怨环境响应慢的时候 ,我们重启一下应...【详细内容】
2021-12-08  Java识堂    Tags:Redis   点击:(18)  评论:(0)  加入收藏
我不知道为什么你会选择对特定数量的“错误”(或警告)如此具体。听起来您正在寻找将要发布到 Yahoo! 的某些文章的内容。 Insider (N Foos to Blah for the BlahBlah)。那说:...【详细内容】
2021-12-07  富集云科技有限公司    Tags:Redis   点击:(14)  评论:(0)  加入收藏
目录 一、背景 二、步骤 0.理论支持 1、获取数据 2、结果 3、分析数据并评估大小 三、关于repl-backlog-size 一、背景 repl-backlog-size控制这个环形缓冲区. ​ 主从断...【详细内容】
2021-11-05  弈秋的美好生活    Tags:redis   点击:(41)  评论:(0)  加入收藏
Redis 性能测试是通过同时执行多个命令实现的。1,Redis-benchmarkRedis性能命令:redis性能命令格式: redis-benchmark [option] [option value] redis 性能测试工具可选参数如...【详细内容】
2021-11-02  川石信息    Tags:Redis   点击:(41)  评论:(0)  加入收藏
1 概述数据结构和内部编码 无传统关系型数据库的 Table 模型schema 所对应的db仅以编号区分。同一 db 内,key 作为顶层模型,它的值是扁平化的。即 db 就是key的命名空间。 key...【详细内容】
2021-11-01  JavaEdge    Tags:Redis   点击:(28)  评论:(0)  加入收藏
普通java中使用引用Java redis 驱动,即可连接:import redis.clients.jedis.Jedis; public class RedisTestJava { public static void main(String[] args) { //连...【详细内容】
2021-10-13  faesuite    Tags:Redis   点击:(34)  评论:(0)  加入收藏
Redis常用的数据结构有 string list set zset hashstringstring 是 Redis 的基本的数据类型,一个 key 对应一个 value。string 类型是二进制安全的,Redis的string可以包含任...【详细内容】
2021-10-12  语霖    Tags:Redis   点击:(36)  评论:(0)  加入收藏
列表类型可以存储一组按插入顺序排序的字符串,它非常灵活,支持在两端插入、弹出数据,可以充当栈和队列的角色。> LPUSH fruit apple(integer) 1> RPUSH fruit banana(integer)...【详细内容】
2021-09-17  深夜敲代码    Tags:Redis   点击:(54)  评论:(0)  加入收藏
Redis持久化意义 是做灾难恢复,数据恢复,也可以归类到高可用的一个环节里面去,比如你的redis整个挂了,然后redis就不可用了,你要做的事情是让redis变得可用,尽快变得可用 大量的请...【详细内容】
2021-08-12  小李说IT    Tags:Redis   点击:(77)  评论:(0)  加入收藏
当查询Redis中没有的数据时,该查询会下沉到数据库层,同时数据库层也没有该数据,当这种情况大量出现或被恶意攻击时,接口的访问全部透过Redis访问数据库,而数据库中也没有这些数据...【详细内容】
2021-07-30  随便t    Tags:缓存穿透   点击:(91)  评论:(0)  加入收藏
最新更新
栏目热门
栏目头条