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

Redis高性能原理

        redis大家都知道拥有很高的性能,每秒可以支持上万个请求,这里探讨下它高性能的原理。单线程架构和io多路复用技术。

一,单线程架构

        单线程架构指的是命令执行核心线程是单线程的,数据持久化、同步、异步删除是其他线程在跑的。redis收到客户端的命令是无序的,谁先来谁就先存起来,存到队列中。然后走队列依次取出命令执行。所以并不会产生并发问题。

        那么为什么单线程反而很快呢?

        1,纯内存访问肯定快。

        2,不涉及多线程切换带来的额外开销。

二,io多路复用

        redis实现了reactor模型,利用linux的epoll机制实现了io多路复用的技术。

        那为什么io多路复用技术就性能高呢?

        因为io多路复用可以在一个监控线程里监听很多连接,没有io操作时只需要挂起监控线程,而不用挂起工作线程。只要有io操作事件到达时,就会唤起监听线程进行处理,而不用轮训判断是否有数据到达。我们试想下并发的连接可能成千上万,如果每个都开个线程处理系统肯定承受不了。就算用线程池,那么线程在阻塞等待时也什么都干不了,而且开几百个线程频繁切换性能也有问题。 

        reactor模型有三个事件:连接事件,读事件,写事件。三个角色:reactor(反应者)、acceptor(接收者)、处理者。

reactor监听事件,如果是连接事件则将事件分给acceptor。acceptor建立连接后创建处理器用于后续读写处理。如果是读写事件时则直接分给handler处理。

常见的慢操作

既然它是单线程架构,那么线程一旦阻塞就会导致后续操作变慢。

1,操作大对象的命令肯定慢。应该将数据拆分到多个key中。

2,keys、sort命令会进行较大计算,会导致阻塞。

3,一些批量操作的命令应该谨慎使用,会导致去多节点取数据,也比较耗时。

相关文章:

  • 掌握Docker:让你的应用轻松部署和管理
  • 使用openai-whisper实现语音转文字
  • 外汇天眼:外汇交易不可不知的8大风险!
  • 欧放ER-2024年1月 AI论文速递
  • Draw.io绘制UML图教程
  • vue3新特性-defineOptions和defineModel
  • 2024 Sora来了!“手机Agent智能体”也来了!
  • MyBatis Plus:自定义typeHandler类型处理器
  • Autodesk CAD如何建立图层方框?
  • Python学习笔记——PySide6设计GUI应用之UI与逻辑分离
  • git中将所有修改的文件上传到暂存区
  • 探索最新AI视频生成技术——OpenAI Sora模型的机遇和挑战
  • websoket
  • CTR之行为序列建模用户兴趣:DIN
  • 用于将Grafana默认数据库sqlite3迁移到MySQL数据库
  • 【Under-the-hood-ReactJS-Part0】React源码解读
  • 【每日笔记】【Go学习笔记】2019-01-10 codis proxy处理流程
  • Angular 2 DI - IoC DI - 1
  • DataBase in Android
  • Joomla 2.x, 3.x useful code cheatsheet
  • React Transition Group -- Transition 组件
  • Redux系列x:源码分析
  • ubuntu 下nginx安装 并支持https协议
  • 对话 CTO〡听神策数据 CTO 曹犟描绘数据分析行业的无限可能
  • 番外篇1:在Windows环境下安装JDK
  • 基于游标的分页接口实现
  • 京东美团研发面经
  • 两列自适应布局方案整理
  • 聊聊spring cloud的LoadBalancerAutoConfiguration
  • 判断客户端类型,Android,iOS,PC
  • 深入浏览器事件循环的本质
  • 思维导图—你不知道的JavaScript中卷
  • 腾讯大梁:DevOps最后一棒,有效构建海量运营的持续反馈能力
  • 提醒我喝水chrome插件开发指南
  • 网页视频流m3u8/ts视频下载
  • 微服务入门【系列视频课程】
  • Mac 上flink的安装与启动
  • 京东物流联手山西图灵打造智能供应链,让阅读更有趣 ...
  • ​软考-高级-系统架构设计师教程(清华第2版)【第9章 软件可靠性基础知识(P320~344)-思维导图】​
  • #define MODIFY_REG(REG, CLEARMASK, SETMASK)
  • $().each和$.each的区别
  • (1)SpringCloud 整合Python
  • (12)目标检测_SSD基于pytorch搭建代码
  • (react踩过的坑)antd 如何同时获取一个select 的value和 label值
  • (超简单)构建高可用网络应用:使用Nginx进行负载均衡与健康检查
  • (力扣)循环队列的实现与详解(C语言)
  • (没学懂,待填坑)【动态规划】数位动态规划
  • (深度全面解析)ChatGPT的重大更新给创业者带来了哪些红利机会
  • (十五)devops持续集成开发——jenkins流水线构建策略配置及触发器的使用
  • (五)IO流之ByteArrayInput/OutputStream
  • (新)网络工程师考点串讲与真题详解
  • (转)C#调用WebService 基础
  • (转)jQuery 基础
  • .Net mvc总结
  • .NET Remoting学习笔记(三)信道