网站首页 > 文章精选 正文
Redis真的是单线程吗?
我们一般说Redis是单线程,是指Redis的网络IO和键值对操作是一个线程完成的,这就是Redis对外提供键值存储服务的主要流程。Redis的其他功能,例如持久化、异步删除、集群数据同步等等都是由额外的线程去做的。当我们说“Redis是单线程高性能的存储”的时候,无非是说法上感觉比较酷。
Redis为啥用单线程?
由于Redis是基于内存的操作,CPU不是Redis的瓶颈,Redis的瓶颈可能是机器内存的大小或网络带宽。既然CPU不是瓶颈,再加上多线程并发还存在共享资源抢占造成的问题,就选择简单的单线程方案了。这个在软件设计中的思路就是,能用简单的方案解决问题就不要玩花活。
单线程Redis为啥这么快?
普通IO模型
对于Redis线程来说,普通的网络IO模型处理主要分为bind/listen、accept、recv、parse等操作,其中accept和recv两个操作可能是阻塞点:
- accept:当线程在等待别的请求的时候,就不做其他的事情;
- recv:当线程在等待数据传输完成的时候,也不做其他事情
高性能IO模型
随着Linux网络编程技术的发展,为了提升效率,逐步引入了IO多路复用+异步非阻塞模式:
- IO多路复用,指的是网络处理线程可以同时监听几个FD上的请求
- 异步非阻塞模式,主要是基于事件的响应式编程模式,线程会注册回调函数到事件队列,当队列里有新的事件产生的时候,就会触发该回调函数的调用,业务的逻辑写在回调函数中
IO多路复用+异步非阻塞模式的具体实现跟操作系统有关:
- 基于 Linux 系统下的 select 和 epoll 实现
- 基于 FreeBSD 的 kqueue 实现
- 基于 Solaris 的 evport 实现
参考资料
- https://cloud.tencent.com/developer/article/1717352
- 《UNIX网络编程》
- 极客时间《Redis核心技术与实战》
- 《Redis设计与实现》
- 《Redis深度历险》
硬核资料:关注即私信可领取行业经典书籍PDF。
技术互助:技术群大佬指点迷津,你的问题可能不是问题,求资源在(技术群)里喊一声。
面试题库:由P8大佬们共同投稿,热乎的大厂面试真题,持续更新中。(关注后私信获取)
知识体系:含编程语言、算法、大数据生态圈组件(Mysql、Hive、Spark、Flink)、数据仓库
猜你喜欢
- 2025-05-22 为什么前端老觉得后端简单?
- 2025-05-22 Apache Log4j高危漏洞,燃爆大厂、燃烧Java开源框架
- 2025-05-22 那些Java架构师必知必会的技术
- 2025-05-22 面试官:项目简单?行,说说怎么把1块钱花出100块效果!
- 2025-05-22 你的项目有'哇'点吗?
- 2025-05-22 你简历里的"技术债"正在劝退面试官!Java老炮亲授3招起死回生术
- 2025-05-22 3天速通Flink!阿里P8教你从入门到实战,3天让你从小白变大神!
- 2025-05-22 一次 Java 架构师面试全记录:从准备到实战的深度复盘
- 2025-05-22 Java人绝地求生!项目被diss像玩具?组合拳直接打服面试官!
- 05-24一文了解工业以太网交换机的作用和工作原理
- 05-24集线器,交换机,路由器工作层次的区别
- 05-24POE交换机供电原理及工作过程介绍
- 05-24如何检查交换机电源的工作状态和健康状况?
- 05-24新手必学!1分钟Get交换机工作原理
- 05-24什么是交换机?交换机工作原理
- 05-24交换机工作原理的直观解释
- 05-24一图搞懂交换机的工作原理
- 最近发表
- 标签列表
-
- newcoder (56)
- 字符串的长度是指 (45)
- drawcontours()参数说明 (60)
- unsignedshortint (59)
- postman并发请求 (47)
- python列表删除 (50)
- 左程云什么水平 (56)
- 计算机网络的拓扑结构是指() (45)
- 编程题 (64)
- postgresql默认端口 (66)
- 数据库的概念模型独立于 (48)
- 产生系统死锁的原因可能是由于 (51)
- 数据库中只存放视图的 (62)
- 在vi中退出不保存的命令是 (53)
- 哪个命令可以将普通用户转换成超级用户 (49)
- noscript标签的作用 (48)
- 联合利华网申 (49)
- swagger和postman (46)
- 结构化程序设计主要强调 (53)
- 172.1 (57)
- apipostwebsocket (47)
- 唯品会后台 (61)
- 简历助手 (56)
- offshow (61)
- mysql数据库面试题 (57)