为什么要io复用

经常看到 select poll epoll 

java 里 nio aio

linux io 线程里有5种io模型.

里面有个重要的概念是 io复用.

    1. 为什么需要io复用 why ?

    2. io复用 怎么改进这个问题的?


1.为什么需要io复用 why ?

先理解下5种io模型.

传统两种阻塞式轮询的问题.都是一个线程监听端口的连接请求,然后产生一个线程去等待该连接的数据.

如果连接数很多的情况下. 会产生成百上万个线程. 

带来的问题.

1.线程唤醒睡醒需要cpu时间

2. 线程本身占用内存空间. java 0.5m大概.

那有什么办法能够解决这个问题呢. 这种轮询的模式改成推的模式. 更及时,更少耗性能. 每次生成一个连接后,把这个连接丢给同一个观察者.

这个观察者会观察百万级别的和客户端的连接. 一旦有数据请求后, 设置该连接状态. 另外一个线程,定时扫描有数据的连接. 告知观察者. 对数据进行相应执行.

由于一个端口的N个连接的数据处理是同构的,只需要一份代码. 执行完毕后.线程回收.

这种一个观察者观察N个连接(IO)的情况就叫做 io复用 

参考文献: 高性能网络编程5–IO复用与并发编程 http://blog.aliyun.com/719  ( 内有数据结构 红黑树的使用 )


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值