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

多路复用和事件轮询机制

多路复用:Nio 服务端只有一个线程处理多个连接
事件轮询机制:select 底层用了 epoll。
select open 调用了
epoll 通过3个方法来实现事件轮询
1.epoll.create 创建epoll 多个集合
2.epoll.ctl 如果有事件会把事件挪到就绪事件列表。
3.epoll.wait 会监听就绪事件列表,如果没有事件就阻塞,如果有事件就跳出阻塞,把事件拿出来逐个执行。

epoll.ctl 是如何把事件挪到就绪事件列表的? 通过操作系统的中断程序。客户端和服务端都是通过端口连接,端口感知到事件后就会触发中断程序。

redis 处理数据的收发是多线程,但是处理业务逻辑是单线程,redis的线程模型就是多路复用。


http://www.mrgr.cn/news/38211.html

相关文章:

  • 大厂面试真题-什么是CAS单点登录?什么原理
  • jupyter快捷键
  • 【JavaEE初阶】深入理解wait和notify以及线程饿死的解决
  • MySQL - 单表查询
  • QQ机器人搭建
  • docker build 有时候不展示命令的输出情况,怎么办?
  • 尚硅谷vue3+TypeScript笔记大全
  • 五.海量数据实时分析-FlinkCDC+DorisConnector实现数据的全量增量同步
  • 递归算法详解
  • 如果只能保留一个复制粘贴软件,那一定是它pastemate
  • LeetCode讲解篇之5. 最长回文子串
  • 笔试练习day6
  • Mysql优化(常见优化)
  • 基于Java的停车场管理微信小程序 停车场预约系统【源码+文档+讲解】
  • [大语言模型-论文精读] 大语言模型是单样本URL分类器和解释器
  • <<迷雾>> 第 2 章 用电来表示数 示例电路
  • 深度学习与数学归纳法
  • springboot+vue+java校园共享厨房菜谱系统
  • feign的全局拦截器和局部拦截器
  • 为啥我关不掉页面?Chrome扩展开发中的那些坑