Redis网络模型

redis为什么快

1.主要原因是因为redis是基于内存操作的,比起直接操作磁盘速度快好几倍

2.基于内存的数据库瓶颈主要是在网络io这一块,redis网络模型 采用io多路复用技术能够高效的处理并发连接。

3.redis使用单线程执行命令,可以避免上下文切换带来的消耗,同时使用多线程处理网络io。

什么是io多路复用?

在这之前我们先了解一下io,网络io又可以为,BIO( 阻塞 io),NIO( 非阻塞 io) AIO( 异步 io)

BIO:当我们应用层想去获取数据时,由于操作系统还没有我们想要的数据,此时recvfrom函数会一直等待直到能获取数据,这个等待的过程就像被阻塞了一样。

NIO:当我们每一次调用recvfrom函数获取数据时,由于数据不存在,操作系统会直接返回结果,并不断的发起recvfrom直到获取数据。就像你们追心爱的女神一样,尽管被拒绝多次,还不停的示爱,总觉得他一定会返回你想要的结果。缺点就是不断的recvfrom做无用的功浪费资源。

什么又是多路复用呢?

如果我们每一个获取数据的请求都交给一个线程处理,我们应用层肯定是有并发请求的,显然我们操作系统共享资源肯定是不足够的。此时我们的计算机行业伟人'牛顿'提出一个想法,让一个线程去监听多个事件fd。什么又是事件fd呢,你可以简单理解成我们每一个io请求在操作系统都有一个存放的地址,我们可以根据这个fd去找到该地址有没有存放数据。

AIO **:**应用程序发起异步 I/O 请求。内核启动 I/O 操作,应用程序可以继续执行其他任务。I/O 操作完成后,内核通知应用程序(回调函数)。应用程序处理 I/O 结果,如读取数据或发送响应。

相关推荐
Agatha方艺璇5 分钟前
CentOS7 Hive2.3.8 安装图文教程
大数据·数据库
EndingCoder22 分钟前
离线应用开发:Service Worker 与缓存
前端·javascript·缓存·性能优化·electron·前端框架
悟乙己25 分钟前
PySpark 与 Pandas 的较量:Databricks 中 SQL Server 到 Snowflake 的数据迁移之旅
数据库·pandas·pyspark
Menior_4 小时前
【MySQL】基本查询
数据库·mysql
一只游鱼5 小时前
Redis入门(部署、持久化、缓存问题)
数据库·redis·缓存
@小匠5 小时前
Spring Cache 多租户缓存隔离解决方案实践
java·spring·缓存
北城以北88885 小时前
数据库--MySQL数据管理
数据库·mysql
代码的余温5 小时前
Oracle RAC共享存储核心技术
数据库·oracle
float_六七6 小时前
数据库物理外键与逻辑外键全解析
数据库·oracle