debug=True
옵션 을 좋아하고 Tornado-multiprocess를 사용 하는 사람들에게는 다음과 같은 오류가 발생합니다.
Traceback (most recent call last):
File "./main.py", line 54, in <module>
server.start(0) # forks one process per cpu
File "/Users/me/Library/Python/2.7/lib/python/site-packages/tornado/tcpserver.py", line 221, in start
process.fork_processes(num_processes)
File "/Users/me/Library/Python/2.7/lib/python/site-packages/tornado/process.py", line 130, in fork_processes
raise RuntimeError("Cannot run in multiple processes: IOLoop instance "
RuntimeError: Cannot run in multiple processes: IOLoop instance has already been initialized. You cannot call IOLoop.instance() before calling start_processes()
이는 debug=True
로드 로 인해 IOLoop
두 번로드 될 수 없기 때문 입니다.
설명서에 따르면
debug = True 설정은 autoreload = True, compile_template_cache = False, static_hash_cache = False, serve_traceback = True와 같습니다.
따라서 debug=True
토네이도를 사용할 때 , 편의를 위해 또 다른 플래그를 설정 autoreload=True
합니다.
autoreload
옵션은 멀티 프로세스를 사용하는 경우에 설정 될 수없는 일이다. 따라서 다음과 같이 구성해야합니다.
if __name__ == "__main__":
application = tornado.web.Application([
(r"/", MainHandler)
], debug=True, autoreload=False)
application.listen(8888)
tornado.ioloop.IOLoop.instance().start()