本文主要研究的是tornado 多进程模式的相关内容,具体如下。
官方文档的helloworld实例中的启动方法:
1
|
if __name__ = = "__main__" :
|
application.listen(8888) # listen is a shortcut for bind and start ,这点看httpserver.py可以得知
1
|
tornado.ioloop.IOLoop.instance().start()
|
并且在listen中,将tornado启动为单进程模型。
所以要启动为多进程模型的方法为:摒弃listen方法
1
2
3
4
5
6
7
|
http_server = tornado.httpserver.HTTPServer(application)
http_server.bind(options.port, options.host)
http_server.start(num_processes = 0 ) # tornado将按照cpu核数来fork进程
tornado.ioloop.IOLoop.instance().start()
|
需要注意的一点是,要关掉debug模式,否则:
1
|
[E 110521 11 : 26 : 53 httpserver: 229 ] Cannot run in multiple processes: IOLoop instance has already been initialized. You cannot call IOLoop.instance() before calling start()
|
原因是,autoreload.py已经在http_server.start()之前就初始化了IOLoop,这个在httpserver.py中的class HTTPServer()和def start()的doc string中已经解释了。
总结
以上就是本文关于tornado 多进程模式解析的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!
原文链接:http://blog.csdn.net/mingzznet/article/details/52929743