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

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 结果,如读取数据或发送响应。

相关文章:

  • 学习笔记:于博士SI揭秘实记第一章 概述
  • RabbitMQ 高级特性解析:RabbitMQ 消息可靠性保障 (上)
  • Visual Studio Code打开远程服务器项目,打开服务器Android上百G源码,SSH免密连接方式
  • 蓝桥杯备考:六级词汇积累(day5)
  • 闭包+求解候选码+最小函数依赖集
  • 【Java代码审计 | 第四篇】SQL 注入防范
  • 什么是JVM
  • 免费开源的小软件,直接
  • golang dlv调试工具
  • 神经网络原理完全解密:从数学根基到前沿模型实战
  • 基于java社交网络安全的知识图谱的构建与实现
  • linux awk命令和awk语言
  • 【认知管理1:从疾病中获得启发 关键字摘取】
  • 智能体开发:推理-行动(ReAct)思维链提示
  • python的内置函数 - round()
  • debian根文件系统制作
  • MySQL 数据库优化与定期数据处理策略
  • C++20的简写函数模板
  • cesium中,获取光标处颜色
  • STM32之BKP
  • 家庭宽带做网站服务器/网站seo应用
  • 好姑娘高清免费观看/上海搜索引擎优化1
  • 网站开发应该怎么做/百度搜索资源平台提交
  • b2b网站制作平台/广告开户
  • 做微商能利用的网站有哪些问题/智谋网站优化公司
  • 哪个网站做首饰批发好/seo综合查询 站长工具