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

Redis为什么选择单线程?Redis为什么这么快?

时间:2023-03-21 11:19:26  来源:微信公众号  作者:哪吒编程
redis6.0引入IO多线程的读写,更高效的处理请求,Redis只是将IO读写变成了多线程,命令的执行还是由主线程单线程执行,因此,多线程下操作Redis不会出现线程安全的问题,不用像JAVA那样加锁,解锁,这也是Redis为什么这么快的根本原因。

 

 

大家好,我是哪吒。

今天搞一下经典面试题Redis为什么选择单线程?Redis为什么这么快?,实现快速入门,丰富个人简历,提高面试level,给自己增加一点谈资,秒变面试小达人,BAT不是梦。

一、Redis版本迭代

图片

  • Redis2.6,支持lua脚本。
  • Redis3.0,支持集群。
  • Redis4.0,混合持久化,多线程异步删除。
  • Redis5.0,核心代码重构。
  • Redis6.0,多线程IO。
  • Redis7.0,Function、Multi-part-AOF。

二、Redis4.0之前为什么一直采用单线程?

1、Redis采用单线程模型方便开发和维护。

2、单线程模型也可以通过IO多路复用和非阻塞IO并发处理多客户端请求。

3、对于Redis来说,主要的性能瓶颈是内存和网络,而不是CPU。

三、Redis6.0引入多线程

Redis6.0之前,Redis从网络IO处理到实际的读写命令处理,都是单线程的,只不过在数据删除、数据持久化的时候使用的是多线程。

Redis的性能瓶颈主要是网络IO,因此,Redis6.0开始,采用多个IO线程来处理网络请求,提高网络请求处理的并行度。

四、Redis主线程和IO线程是如何完成请求的?

图片

1、服务端和客户端建立socket连接

主线程负责建立连接,并把socket放入全局等待队列,主线程通过轮询的方法将socket连接分配给IO线程。

2、IO线程读取并解析请求

主线程一旦把socket分配给IO线程,就会进入阻塞状态,等待IO线程完成客户端请求,此时,采用多个IO线程并行处理。

3、主线程执行请求命令

IO线程解析完请求,主线程还是会以单线程的方式执行这些命令。

4、IO线程会写回socket和主线程清空全局队列

当主线程执行完请求命令后,会将结果写入缓冲区,主线程进入阻塞状态,等待IO线程将结果回写到socket中,并返回给客户端。

回写socket完毕后,主线程清空全局队列。

五、IO多路复用是什么?

IO多路复用,一种同步的IO模型,实现一个线程监视多个文件句柄,一旦某个文件句柄就绪就能够通知到对用的应用程序进行对应的读写操作,没有文件句柄就绪时,程序就会进入阻塞状态,释放CPU资源。

1、IO,操作系统层面指数据在内核态和用户态之间进行的读写操作;

2、多路,多个客户端socket连接;

3、复用,复用线程;

4、IO多路复用,使用单线程就能够同时处理多个客户端socket连接;

客户端socket对应的文件描述符FileDescriptor注册进epoll,epoll会监听哪些socket有消息,避免大量的无用操作。

此时socket采用非阻塞模式,整个过程只在调用select、poll、epoll时才会阻塞,收到客户端消息不会阻塞,这个进程就会被充分利用起来,这种模式一般被称为事件驱动,也就是reactor反应模式。

采用epoll的方式,最终目的是提高服务器的吞吐能力。

IO多路复用与epoll函数才是“Redis为什么这么快?”的直接原因。

六、总结

Redis是一个基于内存操作、KV形式的数据库,采取多路复用、非阻塞IO、避免了不必要的上下文切换等特性。

Redis一直存在BigKey问题,因此在Redis4.0引入了多线程异步删除,正式打开Redis多线程新篇章。

Redis6.0引入IO多线程的读写,更高效的处理请求,Redis只是将IO读写变成了多线程,命令的执行还是由主线程单线程执行,因此,多线程下操作Redis不会出现线程安全的问题,不用像Java那样加锁,解锁,这也是Redis为什么这么快的根本原因。

本文转载自微信公众号「哪吒编程」,可以通过以下二维码关注。转载本文请联系哪吒编程公众号。



Tags:Redis   点击:()  评论:()
声明:本站部分内容及图片来自互联网,转载是出于传递更多信息之目的,内容观点仅代表作者本人,如有任何标注错误或版权侵犯请与我们联系(Email:2595517585@qq.com),我们将及时更正、删除,谢谢。
▌相关推荐
Redis6.0引入IO多线程的读写,更高效的处理请求,Redis只是将IO读写变成了多线程,命令的执行还是由主线程单线程执行,因此,多线程下操作Redis不会出现线程安全的问题,不用像Java那样...【详细内容】
2023-03-21  Tags: Redis  点击:(0)  评论:(0)  加入收藏
引言在海量数据处理领域,统计数据的数量是一个常见的问题。比如统计每个 IP 地址出现的次数,统计每个用户的活跃时段等等。这些问题的数据规模都很大,可能会达到亿级别,对于传统...【详细内容】
2023-03-16  Tags: Redis  点击:(8)  评论:(0)  加入收藏
今天分享一下Redis的持久化、事务、管道相关的知识点,实现快速入门,丰富个人简历,提高面试level,给自己增加一点谈资,秒变面试小达人,BAT不是梦。Redis是一个键值对数据库,服务器中...【详细内容】
2023-03-13  Tags: Redis  点击:(10)  评论:(0)  加入收藏
当Redis中清理了大量的Key之后原先Redis申请的内存(used_memory_rss)将继续持有而不会释放,此时查看内存信息将会看到存在大量的内存碎片。那么,Redis的内存碎片可以清理么,该如...【详细内容】
2023-03-07  Tags: Redis  点击:(15)  评论:(0)  加入收藏
Redis是一个key-value存储系统,支持10种数据类型,总结了为何要用Redis替代map作为程序缓存、Redis为什么是单线程的、Redis的优缺点、Redis的常用场景,做了一次Redis的快速入门...【详细内容】
2023-03-06  Tags: Redis  点击:(13)  评论:(0)  加入收藏
Redis 的 List 与 Java 中的 LinkedList 类似,是一种线性的有序结构,可以按照元素被推入列表中的顺序来存储元素,能满足先进先出的需求,这些元素既可以是文字数据,又可以是二进制...【详细内容】
2023-03-06  Tags: Redis  点击:(7)  评论:(0)  加入收藏
跳表的时间复杂度与AVL树和红黑树相同,可以达到O(logN),但是AVL树要维持高度的平衡,红黑树要维持高度的近似平衡,这都会导致插入或者删除节点时的一些时间开销,所以跳表相较于AVL...【详细内容】
2023-03-02  Tags: Redis  点击:(16)  评论:(0)  加入收藏
基本组件Nginx、Gateway、Nacos、Sentinel、Ribbon、Feign、Seata、Redis、RabbitMQ、MySQL、docker、Vue。大家好,我是哪吒。今天分享一篇一站式微服务架构,读哪吒编程,品技术...【详细内容】
2023-02-27  Tags: Redis  点击:(25)  评论:(0)  加入收藏
Redis是一款高性能的内存数据结构存储系统,能够支持多种数据结构类型,如字符串、哈希、列表、集合、有序集合等,也能够支持高级功能,如事务、发布/订阅、Lua脚本等,具有高可用性...【详细内容】
2023-02-23  Tags: Redis  点击:(14)  评论:(0)  加入收藏
Redis 和 MySQL 都是常用的数据存储工具,但它们的设计和使用场景不同,因此在一些特定的情况下,可能会有不同的表现。Redis 的队列本质上是一种内存数据结构,它是基于内存的,所以...【详细内容】
2023-02-22  Tags: Redis  点击:(6)  评论:(0)  加入收藏
▌简易百科推荐
Redis6.0引入IO多线程的读写,更高效的处理请求,Redis只是将IO读写变成了多线程,命令的执行还是由主线程单线程执行,因此,多线程下操作Redis不会出现线程安全的问题,不用像Java那样...【详细内容】
2023-03-21  哪吒编程  微信公众号  Tags:Redis   点击:(0)  评论:(0)  加入收藏
引言在海量数据处理领域,统计数据的数量是一个常见的问题。比如统计每个 IP 地址出现的次数,统计每个用户的活跃时段等等。这些问题的数据规模都很大,可能会达到亿级别,对于传统...【详细内容】
2023-03-16  互联网技术学堂   今日头条  Tags:Redis   点击:(8)  评论:(0)  加入收藏
今天分享一下Redis的持久化、事务、管道相关的知识点,实现快速入门,丰富个人简历,提高面试level,给自己增加一点谈资,秒变面试小达人,BAT不是梦。Redis是一个键值对数据库,服务器中...【详细内容】
2023-03-13  哪吒  微信公众号  Tags:Redis   点击:(10)  评论:(0)  加入收藏
当Redis中清理了大量的Key之后原先Redis申请的内存(used_memory_rss)将继续持有而不会释放,此时查看内存信息将会看到存在大量的内存碎片。那么,Redis的内存碎片可以清理么,该如...【详细内容】
2023-03-07    今日头条  Tags:Redis   点击:(15)  评论:(0)  加入收藏
Redis是一个key-value存储系统,支持10种数据类型,总结了为何要用Redis替代map作为程序缓存、Redis为什么是单线程的、Redis的优缺点、Redis的常用场景,做了一次Redis的快速入门...【详细内容】
2023-03-06  哪吒编程  微信公众号  Tags:Redis   点击:(13)  评论:(0)  加入收藏
Redis 的 List 与 Java 中的 LinkedList 类似,是一种线性的有序结构,可以按照元素被推入列表中的顺序来存储元素,能满足先进先出的需求,这些元素既可以是文字数据,又可以是二进制...【详细内容】
2023-03-06  就是码哥呀  微信公众号  Tags:Redis   点击:(7)  评论:(0)  加入收藏
跳表的时间复杂度与AVL树和红黑树相同,可以达到O(logN),但是AVL树要维持高度的平衡,红黑树要维持高度的近似平衡,这都会导致插入或者删除节点时的一些时间开销,所以跳表相较于AVL...【详细内容】
2023-03-02  京东云开发者  今日头条  Tags:Redis   点击:(16)  评论:(0)  加入收藏
Redis是一款高性能的内存数据结构存储系统,能够支持多种数据结构类型,如字符串、哈希、列表、集合、有序集合等,也能够支持高级功能,如事务、发布/订阅、Lua脚本等,具有高可用性...【详细内容】
2023-02-23  Java编程世界    Tags:Redis   点击:(14)  评论:(0)  加入收藏
Redis 和 MySQL 都是常用的数据存储工具,但它们的设计和使用场景不同,因此在一些特定的情况下,可能会有不同的表现。Redis 的队列本质上是一种内存数据结构,它是基于内存的,所以...【详细内容】
2023-02-22  区块软件开发  今日头条  Tags:Redis   点击:(6)  评论:(0)  加入收藏
当一个较大的key存在时,持续新增,key所占内存会越来越大,严重时会导致内存数据溢出;当key过期需要删除时,由于数据量过大,可能发生主库较响应时间过长,主从数据同步异常(删除掉的数...【详细内容】
2023-02-16  不才陈某  51CTO  Tags:Redis   点击:(25)  评论:(0)  加入收藏
站内最新
站内热门
站内头条