IO模型学习笔记

本文探讨了高性能编程中的三种程序调用方式:函数调用、系统调用和RPC。重点分析了BIO(阻塞I/O)、NIO(非阻塞I/O)和IO多路复用(如select、poll、epoll)的优缺点。BIO在大量连接时可能导致线程资源浪费和上下文切换频繁;NIO通过少量线程轮询,但存在空轮询问题;而IO多路复用通过一次系统调用来高效获取多个socket状态,epoll作为最优选择,实现了事件驱动的高效处理。
摘要由CSDN通过智能技术生成

高并发,高性能,高可用,三高
高性能:性能是硬件决定的,编写高性能应用程序就是要少浪费硬件资源

程序调用分为
1.函数调用 最快,用户态内内存调用
2.系统调用 调用操作系统内核的函数,要切换内核态,相对更慢
3.RPC调用 应用程序->内核->网卡,最慢

BIO:
每个socket连接都要一个线程去处理,当有一万个客户端连接时也安排一万个线程去处理
缺点,占内存,线程上下文切换频繁

NIO:
固定几个线程去轮询内核的所有socket,找到有数据的socket来处理
缺点,每查询一个socket的状态都要系统调用,一万个socket轮询一次就要一万次系统调用
当一万个socket只有一个有数据时也这样轮询,会有9999个空轮询

IO多路复用:
使用内核的select或者poll或者epoll函数一次性返回所有socket的状态集
优点,只需要一次系统调用就能找到有数据的socket

内核的select或者poll或者epoll这些函数的作用都是返回内核中所有socket的状态集
三个函数有区别,目前epoll最优反正

select:无差别轮询
poll:忙轮询
epoll:事件驱动
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值