当前位置: 首页 > news >正文

Redis单线程还是多线程?IO多路复用原理

在这里插入图片描述

目录

    • 专栏导读
    • 一、Redis版本迭代
    • 二、Redis4.0之前为什么一直采用单线程?
    • 三、Redis6.0引入多线程
    • 四、Redis主线程和IO线程是如何完成请求的?
      • 1、服务端和客户端建立socket连接
      • 2、IO线程读取并解析请求
      • 3、主线程执行请求命令
      • 4、IO线程会写回socket和主线程清空全局队列
    • 五、IO多路复用是什么?
    • 六、总结

专栏导读

🏆作者简介:哪吒,CSDN2022博客之星Top1、CSDN2021博客之星Top2、多届新星计划导师✌、博客专家💪 ,专注Java硬核干货分享,立志做到Java赛道全网Top N。

🏆本文收录于Java基础教程系列(进阶篇),本专栏是针对大学生、初级Java工程师精心打造,针对Java生态,逐个击破,不断学习,打通Java技术栈

🏆订阅后,可以阅读Java基础教程系列(进阶篇)中全部文章包含Java基础、Java高并发、Spring、MySQL等Java进阶技术栈

🏆还可以订阅其姐妹篇Java基础教程系列,包含全部Java基础知识点、Java8新特性、Java集合、Java多线程、Java代码实例理论结合实战,实现Java的轻松学习

🏆哪吒多年工作总结:Java学习路线总结,搬砖工逆袭Java架构师。

🏆面试福音:10万字208道Java经典面试题总结(附答案)

大家好,我是哪吒。

上一篇分享了图解Redis,Redis主从复制与Redis哨兵机制,今天分享一下Redis为什么选择单线程?Redis为什么这么快?,实现快速入门,丰富个人简历,提高面试level,给自己增加一点谈资,秒变面试小达人,BAT不是梦。

一、Redis版本迭代

在这里插入图片描述

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

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

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

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

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

三、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为什么这么快的根本原因。

在这里插入图片描述
在这里插入图片描述

Java学习路线总结,搬砖工逆袭Java架构师

10万字208道Java经典面试题总结(附答案)

Java基础教程系列

Java基础教程系列(进阶篇)

相关文章:

  • Element table组件内容\n换行解决办法
  • Day14 文件操作
  • 【百面成神】Redis基础11问,你能坚持到第几问
  • 配置IDEA自带Maven插件的镜像源
  • 简介虚拟地址空间:保障进程间独立性的机制
  • 【剑指offer】旋转数组的最小数字
  • 手写一个简单的RPC框架
  • 如何创建和编写项目管理计划?
  • 算法设计与分析 实验五 贪心算法
  • 正式环境关闭swagger
  • 动态内存的开辟
  • 【分布式版本控制系统Git】| IDEA 集成 Git 、IDEA 集成 GitHub
  • C语言指针链表
  • 全网最完整,接口测试总结彻底打通接口自动化大门,看这篇就够了......
  • 【JVM虚拟机面试宝典】JVM的内存结构是怎么样的?在JVM中会发生内存溢出的区域有那些?— day06
  • 《Java8实战》-第四章读书笔记(引入流Stream)
  • Angular 响应式表单之下拉框
  • Git同步原始仓库到Fork仓库中
  • Java IO学习笔记一
  • JavaScript标准库系列——Math对象和Date对象(二)
  • JavaSE小实践1:Java爬取斗图网站的所有表情包
  • JDK9: 集成 Jshell 和 Maven 项目.
  • leetcode98. Validate Binary Search Tree
  • Linux CTF 逆向入门
  • npx命令介绍
  • Redis学习笔记 - pipline(流水线、管道)
  • 初探 Vue 生命周期和钩子函数
  • 等保2.0 | 几维安全发布等保检测、等保加固专版 加速企业等保合规
  • 多线程事务回滚
  • 学习JavaScript数据结构与算法 — 树
  • 验证码识别技术——15分钟带你突破各种复杂不定长验证码
  • 责任链模式的两种实现
  • #我与Java虚拟机的故事#连载06:收获颇多的经典之作
  • (007)XHTML文档之标题——h1~h6
  • (rabbitmq的高级特性)消息可靠性
  • (附源码)springboot 房产中介系统 毕业设计 312341
  • (附源码)ssm高校志愿者服务系统 毕业设计 011648
  • (附源码)ssm学生管理系统 毕业设计 141543
  • (算法设计与分析)第一章算法概述-习题
  • (转)Linux整合apache和tomcat构建Web服务器
  • (转)关于pipe()的详细解析
  • .NET Core工程编译事件$(TargetDir)变量为空引发的思考
  • .Net 高效开发之不可错过的实用工具
  • .NET 使用 JustAssembly 比较两个不同版本程序集的 API 变化
  • .net/c# memcached 获取所有缓存键(keys)
  • .net开发引用程序集提示没有强名称的解决办法
  • .Net转前端开发-启航篇,如何定制博客园主题
  • :not(:first-child)和:not(:last-child)的用法
  • @Mapper作用
  • [ 隧道技术 ] 反弹shell的集中常见方式(二)bash反弹shell
  • [APUE]进程关系(下)
  • [BZOJ2208][Jsoi2010]连通数
  • [cb]UIGrid+UIStretch的自适应
  • [Latex学习笔记]数学公式基本命令
  • [LeetCode] 197. 上升的温度