网站建设销售实习报告,安卓开发课程,手机可以搭建网站么,网站运营指标目录专栏导读一、Redis版本迭代二、Redis4.0之前为什么一直采用单线程#xff1f;三、Redis6.0引入多线程四、Redis主线程和IO线程是如何完成请求的#xff1f;1、服务端和客户端建立socket连接2、IO线程读取并解析请求3、主线程执行请求命令4、IO线程会写回socket和主线程清…
目录专栏导读一、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经典面试题总结(附答案) 大家好我是哪吒。
上一篇分享了图解RedisRedis主从复制与Redis哨兵机制今天分享一下Redis为什么选择单线程Redis为什么这么快实现快速入门丰富个人简历提高面试level给自己增加一点谈资秒变面试小达人BAT不是梦。
一、Redis版本迭代 Redis2.6支持lua脚本Redis3.0支持集群Redis4.0混合持久化多线程异步删除Redis5.0核心代码重构Redis6.0多线程IORedis7.0Function、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资源。
IO操作系统层面指数据在内核态和用户态之间进行的读写操作多路多个客户端socket连接复用复用线程IO多路复用使用单线程就能够同时处理多个客户端socket连接
客户端socket对应的文件描述符FileDescriptor注册进epollepoll会监听哪些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基础教程系列进阶篇