Для тих, хто любить цю debug=True
опцію та використовує мультипроцес Tornado, з’явиться наступна помилка:
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
його неможливо два рази.
Відповідно до документації
Встановлення налагодження = True еквівалентно автоматичному завантаженню = True, compiled_template_cache = False, static_hash_cache = False, serve_traceback = True.
Тож при використанні debug=True
Tornado також встановлюється (для зручності) ще один прапор: autoreload=True
який "стежить" за змінами та перезавантажує сервер.
autoreload
Варіантом є той , який не може бути включений при використанні мульти-процес. Тому вам потрібно налаштувати його так:
if __name__ == "__main__":
application = tornado.web.Application([
(r"/", MainHandler)
], debug=True, autoreload=False)
application.listen(8888)
tornado.ioloop.IOLoop.instance().start()