名词解析

多路:多个客户端连接(连接就是套接字描述符)

复用:使用单进程就能够实现同时处理多个客户端的连接

为什么 Redis 中要使用 I/O 多路复用?

首先,Redis 是在单线程执行,所有的操作都是按顺序线性执行的,但是由于读写操作等待用户输入或输出都是阻塞的,所以 I/O 操作在一般情况下往往不能直接返回,这会导致某一文件的 I/O 阻塞导致整个进程无法对其它客户提供服务,而 I/O 多路复用就是为了解决这个问题而出现的。

Redis 的 IO 模型主要是基于 epoll 实现的,不过它也提供了 select 和 kqueue 的实现,默认采用 epoll 。

Redis 使用多路复用技术,可以处理并发的连接。非阻塞 IO 内部实现采用epoll,采用了epoll+自己实现的简单的事件框架。epoll 中的读、写、关闭、连接都转化成了事件,然后利用 epoll 的多路复用特性,绝不在io上浪费一点时间。

在多路复用IO模型中,会有一个内核线程不断地去轮询多个 socket 的状态,只有当真正读写事件发送时,才真正调用实际的IO读写操作。因为在多路复用IO模型中,只需要使用一个线程就可以管理多个socket,系统不需要建立新的进程或者线程,也不必维护这些线程和进程,并且只有真正有读写事件进行时,才会使用IO资源,所以它大大减少来资源占用。

多路I/O复用模型是利用 select、poll、epoll 可以同时监察多个流的 I/O 事件的能力,在空闲的时候,会把当前线程阻塞掉,当有一个或多个流有 I/O 事件时,就从阻塞态中唤醒,于是程序就会轮询一遍所有的流(epoll 是只轮询那些真正发出了事件的流),并且只依次顺序的处理就绪的流,这种做法就避免了大量的无用操作。

采用多路 I/O 复用技术可以让单个线程高效的处理多个连接请求(尽量减少网络 IO 的时间消耗),且 Redis 在内存中操作数据的速度非常快,也就是说内存内的操作不会成为影响Redis性能的瓶颈。

多路复用快的原因在于,操作系统提供了这样的系统调用,使得原来的 while 循环里多次系统调用,变成了一次系统调用 + 内核层遍历这些文件描述符。

为啥Redis单线程模型也能效率这么高?

纯内存操作

Redis 将所有数据放在内存中,内存的响应时长大约为 100 纳秒,这是 redis 的 QPS 过万的重要基础。

核心是基于非阻塞的IO多路复用机制

有了非阻塞 IO 意味着线程在读写 IO 时可以不必再阻塞了,读写可以瞬间完成然后线程可以继续干别的事了。

redis 需要处理多个 IO 请求,同时把每个请求的结果返回给客户端。由于 redis 是单线程模型,同一时间只能处理一个 IO 事件,于是 redis 需要在合适的时间暂停对某个 IO 事件的处理,转而去处理另一个 IO 事件,这就需要用到IO多路复用技术了, 就好比一个管理者,能够管理个socket的IO事件,当选择了哪个socket,就处理哪个socket上的 IO 事件,其他 IO 事件就暂停处理了。

单线程反而避免了多线程的频繁上下文切换带来的性能问题

  • 单线程可以简化数据结构和算法的实现。并发数据结构实现不但困难而且开发测试比较麻
  • 单线程避免了线程切换和竞态产生的消耗,对于服务端开发来说,锁和线程切换通常是性能杀手

单线程的问题:

对于每个命令的执行时间是有要求的。如果某个命令执行过长,会造成其他命令的阻塞,所以 redis 适用于那些需要快速执行的场景。

Redis 多路复用相关推荐

  1. redis 十一. IO 多路复用

    目录 一. 基础 select poll epoll 二. redis 与多路复用 一. 基础 首先知道一下五种io模型有个概念 Blocking IO: 阻塞IO NoneBlockin IO: 非 ...

  2. key redis 遍历_快乐运维Redis大数据量查询与清理

    一. keys命令(生产环境禁止使用) 简单粗暴,由于Redis单线程这一特性,keys命令是以阻塞的方式执行的,keys是以遍历的方式实现的复杂度是 O(n),Redis库中的key越多,查找实现代 ...

  3. redis核心技术与实战(四)高可用高扩展篇

    1.<redis架构组成> 1.redis学习维度 2.一个基本的键值型数据库包括什么? 1.访问框架 redis通过网络框架进行访问,使得 Redis 可以作为一个基础性的网络服务进行访 ...

  4. 采坑记录-Redis使用scan代替keys

    [提前声明] 文章由作者:张耀峰 结合自己生产中的使用经验整理,最终形成简单易懂的文章 写作不易,转载请注明,谢谢! spark代码案例地址: https://github.com/Mydreaman ...

  5. Redis遍历、模糊匹配key的两个命令keys、scan(python使用Redis)

    Redis遍历.模糊匹配key的两个命令keys.scan(python使用Redis) (1)全量遍历–keys命令 获取Redis中的所有键: import redis pool=redis.Co ...

  6. [图文讲解]redis命令keys和scan的区别

    1. Keys 命令 语法 redis KEYS 命令基本语法如下: redis 127.0.0.1:6379> KEYS PATTERN KEYS命令使用很简单,查找以 com 为开头的 ke ...

  7. 各大公司java面试整理对应问题博客整理

    各大公司java面试整理对应问题博客整理! 阿里 分库分表 数据库中间件 MyCAT是一个强大的数据库中间件,不仅仅可以用作读写分离,以及分表分库.容灾管理,而且可以用于多租户应用开发.云平台基础设施 ...

  8. 各大互联网厂面试题(付详细答案,持续更新中...)

    文章目录 携程 1. 上来就手撕单例模式,线程安全的懒汉模式的实现,然后问怎么优化,双重锁校验,如果要实现变量可见性?** 2. 线程池相关核心线程满了线程放哪里?阻塞队列满了放哪里?基本线程和阻塞队 ...

  9. 毕业两年,一年工作经验,一个月拿下腾讯T4 offer

    前言: 现在面试可以说是老生常谈的一个问题了,确实也是这么回事.面试题.面试宝典.面试手册......各种面试题一搜一大把,根本看不完,也看不过来,而且每份面试资料也都觉得Nice,然后就开启了收藏之 ...

最新文章

  1. Hive _偏门常用查询函数(二)附带实例(列转行、窗口函数)
  2. Mysql能删了重装吗_mysql卸载重新安装
  3. 每日算法系列【LeetCode 1039】多边形三角剖分的最低得分
  4. DiscuzNT改造系列之删除帖子后论坛版块列表同步更新
  5. wps 打开xml格式乱码_WPS文件打开之后是乱码
  6. Win32软件开发: 按键精灵 鼠标模拟器(VibraClick)
  7. python菜鸟教程 | if else 判断
  8. js实现轮播图背景色随之渐变的效果(小程序版)
  9. axure树形表格_excel树状图怎么做
  10. 动态桌面软件测试简历,动态壁纸软件横评
  11. tf.expand_dims()和tf.squeeze()的用法详解
  12. typedef的用法简介
  13. HBase 2.0 API 初步窥探
  14. 名人彩票Android客户端,名人彩票线路登录
  15. 可以听歌玩游戏看股票背单词的ROS开发工具?小鱼:就差能点外卖了~
  16. 【推荐系统】4种推荐引擎预测你的电影品味
  17. rac节点时间同步方法
  18. 图像上色 (Image-Colorization) 项目
  19. 【每周研报复现】基于阻力支撑相对强度(RSRS)的市场择时
  20. ROLAP,MOLAP和HOLAP之间的区别

热门文章

  1. 图文:windows7文件夹权限添加_解决目标文件夹访问被拒绝
  2. 千言实体链指赛事登顶,冠军团队经验独家分享
  3. 为你讲述陈岷学医的缘
  4. 计算机专业怎样成为学霸的,清华计算机专业的学霸说,这四个学习方法非常实用!...
  5. windows下搭建syslog服务器及基本配置
  6. 漫步者蓝牙自动断开_2020年热门品牌真无线蓝牙耳机排行榜10强介绍
  7. PyTorch中permute的用法
  8. 基于Windows10安装docker服务
  9. 安装配置无线 SONOS HIFI 系统 (完整版)
  10. 要把网络安全像消防安全一样重视起来