在使用webpy时发现的web.application reload的猫腻,暂时记录下来,以便自己和他人参考。
现象是这样的:
在配置文件中定义urls:
urls = (
# front page
"/", "app.controllers.base.index",
"/index/", "app.controllers.base.index",
)
同时为了隐藏部分url对应关系,在程序中增加url映射关系如下:
self._app.add_mapping(url_login, Login)
self._app.add_mapping(url_logout, Logout)
启动webpy主程序代码如下:
app = web.application(urls, globals())
app.run()
系统运行时访问url_login却提示404 Not Found错误,也就是说程序中增加(url_login, Login)的映射并没有真正成功。
通过跟踪分析webpy源码发现,原来webpy为了提高开发环境下的调试效率,特意在构造application时可以指定是否autoreload url配置,如果在创建application时autoreload为None或者web.config.debug 为 True,则在每次处理每一个request时都重新加载mapping,如果autoreload为True,则每次重新构建时mapping都被初始化为创建application时传入的urls。也就是说在程序中增加的mapping都会在处理request时被清除。
为解决这一问题,可以在创建application时将autoreload设置为False或者将web.config.debug设置为False,代码如下
# in development debug error messages and reloader
web.config.debug = False
# in production, we should disable the autoreload of the urls mapping
app = web.application(urls, globals(), autoreload = False)