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

Redis是单线程性能还高的原因

Redis是单线程

Redis单线程是指Redis的网络IO和键值对读写是由一个线程完成的,其他功能还是使用多线程执行

Redis主干业务使用单线程的原因

Redis本质就是一个大的共享资源,共享资源是需要对其进行并发控制的,即使增加了线程,大部分线程也是在等待互斥锁,并行变串行,而且还需要进行并发控制,反而效率变慢了
所以Redis网络IO和键值对读写采用单线程反而效率是最高的

Redis性能高的原因

1、Redis的大部分操作在内存上完成,再加上它采用了高效的数据结构

2、Redis采用多路复用机制,其在网络IO操作中能并发处理大量的客户端请求,实现高吞吐率

Redis多路复用机制运行过程

Redis是使用网络IO进行数据请求和返回的,网络IO中socket由分为读和写

socket和线程是两个概念,可以理解为socket是一个网络通信的通道提供读写操作的,线程是处理这些操作的

传统堵塞IO,是Redis需要处理完一个socket请求,等待它返回,最后得到结果,再处理下一个

传统非阻塞IO则是一直遍历socket请求是否成功,如果成功就返回,如果失败不返回,一直轮询,最早的Redis就是采用的这一方式

现在的多路IO复用是指我现在使用单线程管理多个socket,使用事件监听的方式监听每个socket,那个socket可以返回数据了,就直接使用内核通知线程返回

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

相关文章:

  • Redis缓存击穿、穿透雪崩
  • 【递归完全搜索】USACO Bronze 2018 December - 往返搬运Back and Forth
  • Python字典高阶操作:高效提取子集的技术与工程实践
  • RAG初步实战:从 PDF 到问答:我的第一个轻量级 RAG 系统(附详细项目代码内容与说明)
  • React 状态管理入门:从 useState 到复杂状态逻辑
  • React+TypeScript代码注释规范指南
  • HTML5 Web Workers 深度剖析:助力网页性能飞速提升
  • 3- Python 网络爬虫 — 如何抓取动态加载数据?Ajax 原理与实战全解析
  • 亚马逊广告运营如何平衡ASIN投放和关键词投放
  • 1688 图片搜图找货接口开发实战:从图像特征提取到商品匹配全流程
  • 塑料可回收物检测数据集-10,000 张图片 智能垃圾分类系统 环保回收自动化 智慧城市环卫管理 企业环保合规检测 教育环保宣传 供应链包装优化
  • 快速入门flask应用(从入门到实战)
  • 客户端攻击防御:详解现代浏览器安全措施
  • 彻底解决Hewlett-Packard - USB - 4/8/2019 12:00:00 AM - 1.0.0.237问题
  • 下一代防火墙技术
  • web端-登录页面验证码的实现(springboot+vue前后端分离)超详细
  • 《Graph machine learning for integrated multi-omics analysis》
  • 从C学C++(9)——运算符重载
  • 使用Python爬虫,selenium能否替代requests?
  • 利用哥斯拉(Godzilla)进行文件上传漏洞渗透实战分析
  • 爬虫逆向之雷池waf
  • 使用 PicGo 与 GitHub 搭建高效图床,并结合 Local Images Plus 备份原图
  • Kiro :从“规范”到“实现”的全流程 AI 助手
  • 线程池分析与设计
  • 豆包新模型+PromptPilot:AI应用开发全流程实战指南
  • 图片识别表格工具v3.0绿色版,PNG/JPG秒变可编辑Excel
  • 深入理解模板方法模式:框架设计的“骨架”艺术
  • Shell解释器
  • $QAXHoneypot是什么文件夹
  • 【入门级-C++程序设计:9、函数与递归-传值参数与传引用参数】