【后端修行之Netty】5种I/O模型

本文用于记录苦啃《Netty权威指南 第2版》后,个人认为有价值的笔记,核心内容均围绕标题展开。既做一个学习的记录,同时也做一个沟通交流,欢迎各位大佬互动~

写在前面:

针对所谓的同步/异步,需要具体到I/O过程来看:

一个I/O过程涉及两步:①I/O调用;②I/O执行(执行又具体分为两步:内核数据缓冲区等待数据+内核数据缓冲区数据复制到用户进程缓冲区)。

在这个过程中,所谓的同步是指数据从内核数据缓冲区复制到用户进程缓冲区的过程需要用户进程参与;而异步是指不需要用户进程参与这个过程。

UNIX网络编程将I/O模型分成五种模型:

阻塞I/O模型:调用后阻塞,直至调用完成或者发生错误才返回.

非阻塞I/O模型:调用后立即返回结果,并轮询结果确认数据已到内核.

I/O复用模型:进程将一个或多个fd换地给select和poll,阻塞在select操作上,select/poll循序扫描fd是否就绪.Linux还提供了一个epoll系统调用,基于事件驱动代替顺序扫描,性能更高.一旦fd就绪,立即回调函数rollback.

信号驱动I/O模型:系统调用sigaction执行一个信号处理函数,系统立即返回,进程继续工作.当数据就绪,会为该进程SIGIO信号通知应用程序调用,并读取数据.

异步I/O模型:告知内核某个操作,当某个操作完成后,通知进程.

  • 14
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值