玩蛇记-使用Tornado构建高性能Web之二-autoreload
书接上回,在本系列的第一部分,我们创建了一个helloword的应用,并且能够通过浏览器访问它,这样我们就可以用Tornado来开发网站了,嗯,这是可喜的第一步,不过当你决定了用tornado开发网站,并且开始写新的handler的时候,你会发现需要频繁的,关掉,再重新启动服务器,这是一件非常让人抓狂的事情,我们需要在程序修改后,服务能够自动reload新的代码,和asp.net一样。但是tornado的文档实在是有限,在文档上找不到相关的任何说明。
但是山穷水尽疑无路柳暗花明又一村,无意在源代码里发现了一个autoreload.py的文件
猜想其实tornado是可以自己reload的,不过文档里没有说明,但是autoreload要怎么用呢。打开这个文件,看到其实里面很简单,只有两个函数,如下图
第二个函数是私有的,所以实际上start就是唯一的入口,我们在代码中发现,_reload_on_update函数其实在start中被作为一个回调函数注册到了io_loop中了,所以实际上我们只需要把ioloop传入start就可以实现autoreload了。所以将
def main():
tornado.options.parse_command_line()
application = tornado.web.Application([
(r"/", MainHandler),
])
http_server = tornado.httpserver.HTTPServer(application)
http_server.listen(options.port)
tornado.ioloop.IOLoop.instance().start()
这些代码改为:
def main():
tornado.options.parse_command_line()
application = tornado.web.Application([
(r"/", MainHandler),
])
http_server = tornado.httpserver.HTTPServer(application)
http_server.listen(options.port)
loop=tornado.ioloop.IOLoop.instance()
tornado.autoreload.start(loop)
loop.start()
这样子就行了。
注意,这里的reload只检测py文件的变动,如果是其他文件发生变动,比如css,图片这些,都不会引发reload。