Redis为什么快?

(1)Redis是基于内存存储

(2)IO多路复用,正常来说每个客户端和服务器连接,每个连接都需要一个线程。但不是每个连接时时刻刻都有数据的,维护太多的线程会浪费资源,通过IO多路复用可以让一个线程监控多个socket连接。select 、poll、epoll--》三个IO复用模型

(3)处理命令是单线程 减少上下文切换。一个CPU同时只能执行一个线程的任务,如果是多线程的场景的话,不同线程去争夺CPU资源,上下文切换开销很大,所以redis采用了单线程。 (注:Redis 6.0之前,服务端和客户端的连接以及如何去处理客户端的命令都是共用一个线程的,也就是单线程 , 在Redis 6.0之后,处理服务端和客户端的连接专门用多线程去跑了,但是处理命令还是单线程。)

相关推荐
万少40 分钟前
万少的博客 - 技术分享与解决方案
前端·javascript·后端
咖啡八杯1 小时前
GoF设计模式——备忘录模式
java·后端·spring·设计模式
苍何1 小时前
腾讯再放大招,企微 Agent 大圆开启内测
后端
ethantan1 小时前
一篇讲解AI Agent 组成:像人一样思考的智能体
人工智能·后端·程序员
Cosolar3 小时前
vLLM 生产级部署完全指南
人工智能·后端·架构
IT_陈寒4 小时前
垃圾回收器选错了,我的Java服务内存炸了
前端·人工智能·后端
先吃饱再说4 小时前
存储的进化:从 MySQL 到浏览器缓存,数据到底住在哪?
数据库
用户8356290780515 小时前
使用 Python 在 PDF 中创建与管理书签
后端·python
Nturmoils5 小时前
字段太多看不全,ksql 的展开模式和输出控制怎么用
数据库·后端
大志说编程5 小时前
Agent面试真题06: 十分钟带你快速掌握Agent记忆管理高频面试题(附详细答案)
后端·面试·ai编程