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

redis多路复用IO模型 以及 6.0引入的多线程模型

redis为什么选择单线程

  1. 采用多线程的话,会出现上下文切换的开销
  2. 采用多线程,会带来共享资源的竞争控制,比如多个线程同时访问同一个资源(键值)时,需要额外的手段来保障共享资源的正确性,会带来额外的开销。多线程开发会引入同步语句来保护共享资源的并发访问,会降低代码的可调试性和可维护性。

为什么redis采用单线程还能如此的快

  1. 大部分操作在内存上完成
  2. 采用了高效的数据结构,如 跳表、哈希表。
  3. 采用了多路IO复用机制,使其在网络IO的操作下,能并发的处理大量客户端的请求,实现高吞吐量。

IO多路复用指的是,Redis采用linux的Epoll机制,实现内核中同时存在多个监听中的套接字和已监听的套接字,内核会一直监听这些套接字,一但有请求到达时,就会放到事件队列中,redis的主线程会不断从事件队列中取事件去消费。
在这里插入图片描述

redis 6.0版本引入的多线程

redis在6.0版本引入了多线程,其实不仅仅实在6.0,在6.0版本之前,redis也有其他线程在工作,比如rdb文件备份。6.0之后实在IO多路复用的流程中引入了多线程。
为什么引入多线程,因为读写网络的网络调用在redis执行期间占据了大量的时间。如果把网络读写交给线程组实现,会带来很大的方便,多线程只用在网络的读写和协议解析,执行redis命令的仍然是主线程,也不会带来资源竞争等问题。
在这里插入图片描述
在这里插入图片描述

http://www.xdnf.cn/news/4558.html

相关文章:

  • string[字符串中第一个的唯一字符][蓝桥杯]
  • 数据中台-常用工具组件:DataX、Flink、Dolphin Scheduler、TensorFlow和PyTorch等
  • Oracle 19c中的私有临时表
  • 不再踩坑!React.memo正确用法及性能优化实战
  • 【C++ Qt】多元素控件(ListWidget、TableWidget、TreeWidget)
  • 阿里云ddos云防护服务器有哪些功能?ddos防御手段有哪些??
  • 若依框架Ruoyi-vue整合图表Echarts中国地图标注动态数据
  • python调用国税乐企直连接口开数电票之查询税收分类编码信息
  • spring cloud alibaba nacos 服务注册
  • 远程桌面软件推荐
  • Java 中的 this 关键字完全指南:从原理到实战应用
  • C语言--字符函数
  • 面向智能体开发的声明式语言:可行性分析与未来图景
  • 搭建部署企业级Harbor镜像仓库
  • Docker容器网络架构深度解析与技术实践指南——基于Linux内核特性的企业级容器网络实现
  • 2D横板跳跃游戏笔记(查漏补缺ing...)
  • 可重入锁理解(redission)
  • 5.7线性动态规划1
  • Linux系统基本指令和知识指南
  • 解锁AI绘画新境界!开源文生图解锁AI图像生成无限创意
  • Android 数据持久化之 Room 数据库存储
  • 电子商务商家运营简历模板
  • 协变(Covariance)与逆变(Contravariance)的入门理解
  • STC单片机--仿真调试
  • LLM词编码机制:词映射
  • Git笔记
  • 数据结构、刷leetcode返航版--二分【有序】5/7
  • HPDDM库使用指南与示例
  • 力扣刷题[特殊字符]
  • 力扣-hot100(旋转图像)