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

Redis是单线程还是多线程?(面试题)

1、Redis5及之前是单线程版本
2、Redis6开始引入多线程版本(实际上是 单线程+多线程 版本)

Redis6及之前版本(单线程)

Redis5及之前的版本使用的是 单线程,也就是说只有一个 worker队列,所有的读写操作都要在这一个队列进行操作,好处是不会有线程安全问题(因为它在读写时就只有一个线程,那对于读写操作肯定没有线程安全问题啊!),但是读写 write、read 这些系统调用在Redis执行期间占用了大部分的 CPU 时间,所以这就是单线程模式的缺点。
所以也就在Redis6引入了多线程版本,接着往下看。

Redis6(单线程+多线程)

Redis6引入了多线程机制,但是不是说有多个worker线程同时并发读写, 而是它有 “一个 worker线程+多个IO子线程”,其实就是在 IO 就绪之后使用多线程提升读写解析数据的效率,而在 操作内存数据的时候还是用单线程。
利用这种单线程+多线程共同运作的机制,将CPU的性能显著提升了。

同时,这种机制同样不会产生线程安全问题,因为Redis在针对数据的内存操作时,是在一个公共的worker队列中实现的,先进先出,所以不会有线程安全问题。

Redis6之所以保留worker单主线程是因为单线程机制使得Redis内部实现的复杂度大大降低,而且可以保证操作的线程安全。(如果整个过程全让子线程做了,整个任务处理过程太重,就失去了原来单线程高效处理的优势了)

 

http://www.lryc.cn/news/326677.html

相关文章:

  • 动态菜单设计
  • Haproxy负载均衡介绍即部署
  • 基于大语言模型的云故障根因分析|顶会EuroSys24论文
  • Windows直接运行python程序
  • 经典应用丨光伏行业扫码追溯新标杆,海康机器人AI智能读码器!
  • 逆流而上的选择-积极生活,逆流而上
  • SpringMVC基础Controller
  • spark 参数
  • java调用jacob进行文件转换ppt转pdf或者png
  • 鸿蒙HarmonyOS应用开发之使用DevEco Studio模板构建NDK工程
  • uniapp流浪动物救助小程序Java宠物领养小程序springboot
  • 工程企业的未来选择:Java版工程项目管理系统平台与数字化管理的融合
  • Vue使用el-statistic和el-card显示大屏中的统计数据
  • 12.2024
  • 【学习心得】Jupyter常用操作与魔法方法
  • Linux命令别名
  • Docker和 Containerd 的区别
  • Qt实现TFTP Server和 TFTP Client(二)
  • 【b站李炎恢】Vue.js Element UI | 十天技能课堂 | 更新中... | 李炎恢
  • AI大语言模型工程师学习路线
  • 基于树莓派实现 --- 智能家居
  • 基于Arduino IDE 野火ESP8266模块 一键配网 的开发
  • 左手医生:医疗 AI 企业的云原生提效降本之路
  • ceph集群部署
  • C#WPF控件Label宽度绑定到父控件的宽度
  • HMI的学习
  • 工业无线网关在汽车制造企业的应用效果和价值-天拓四方
  • 校园app开发流程-uniapp开发-支持APP小程序H5-源码交付-跑腿-二手市场-交友论坛等功能,学校自由选择!
  • Machine Learning机器学习之K近邻算法(K-Nearest Neighbors,KNN)
  • 四、在数据库里建库