经常看到 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 ( 内有数据结构 红黑树的使用 )