想弄清楚tornado的Epoll
产品版本: Tornado最新
操作系统: Linux
Python 2.7.x
天蓬老师2017-04-18 10:25:12
可以去看tornado
的ioloop
模組。裡面有說明
...
class IOLoop(Configurable):
"""A level-triggered I/O loop.
We use `epoll` (Linux) or `kqueue` (BSD and Mac OS X) if they
are available, or else we fall back on select(). If you are
implementing a system that needs to handle thousands of
simultaneous connections, you should use a system that supports
either `epoll` or `kqueue`.
...
在Linux
系统中用epoll
,BSD
或Mac OS X
用kqueue
,其他系统中用select
。
使用的是python
标准库中的select
模块。实际上select
模块也只是对系统的select
的調用,並沒有自己實現。
想深入研究的話可以看源碼
感謝 @依雲 的補充。 python
标准库中的select
模块是对系统各种I/O
復用方案的封裝。
>>> import platform
>>> platform.linux_distribution()
('Red Hat Enterprise Linux Server', '6.5', 'Santiago')
>>> import select
>>> dir(select)
['EPOLLERR', 'EPOLLET', 'EPOLLHUP', 'EPOLLIN', 'EPOLLMSG', 'EPOLLONESHOT', 'EPOLLOUT',
'EPOLLPRI', 'EPOLLRDBAND', 'EPOLLRDNORM', 'EPOLLWRBAND', 'EPOLLWRNORM', 'PIPE_BUF',
'POLLERR', 'POLLHUP', 'POLLIN', 'POLLMSG', 'POLLNVAL', 'POLLOUT', 'POLLPRI', 'POLLRDBAND',
'POLLRDNORM', 'POLLWRBAND', 'POLLWRNORM', '__doc__', '__file__', '__name__',
'__package__', 'epoll', 'error', 'poll', 'select']