当前位置: 技术问答>linux和unix
linux并发服务器中epoll+多线程分别怎么理解?
来源: 互联网 发布时间:2016-11-01
本文导语: linux并发服务器中可以用epol来实现 我看了几次epoll的工作原理 就是不是很明白,epoll再加上多线程实现的话 我就更不明了。请知道的帮我讲讲他们怎么揉在一起?同时使用多线程和epoll的工作原理是啥啊? ...
linux并发服务器中可以用epol来实现 我看了几次epoll的工作原理 就是不是很明白,epoll再加上多线程实现的话 我就更不明了。请知道的帮我讲讲他们怎么揉在一起?同时使用多线程和epoll的工作原理是啥啊?
|
你这个问题问的有点广,我不敢回答,怕误人子弟~哈哈
给你点建议吧~~
高吞吐量,低延迟的网络编程关键
1.不要采用一个连接一个线程的方式,而是尽量利用操作系统的事件多路分离机制
如:UNIX下的 select linux下的epoll BSD下的kqueue
或者使用这些机制的高层API (boost.asio&&ACE Reactor)
2.尽量使用异步I/O,而不是同步
3.当事件多路分离单线程无法满足并发需求时,将事件多路分离的线程扩展成线程池
|
某个线程处理某个特定事件吧
通过epoll检测一些事件,事件触发时,创建一个线程来专职处理这个事件
通过epoll检测一些事件,事件触发时,创建一个线程来专职处理这个事件