如果我们检查的文档flask应用全球,
flask.g它说:
要仅对一个函数的一个请求与另一个函数共享有效的数据,全局变量不够好,因为它会在线程环境中中断。Flask为您提供了一个 特殊的对象 ,该
对象 确保它 仅对活动请求有效, 并且将为每个请求返回不同的值。
这是通过使用线程本地代理(在中
flask/globals.py)实现的:
g = LocalProxy(partial(_lookup_app_object, 'g'))
我们应该记住的另一件事是,Python正在“编译”阶段执行装饰器的第一遍,而不是在任何请求或
flask应用程序之外。这意味着在请求上下文之外,为
key参数分配了一个值,该值是
'shop_{}_style'.format(g.city.id)您的应用程序启动时(当类被解析/修饰时)
flask。
但是我们可以
flask.g通过使用延迟代理轻松地延迟访问,该代理仅通过回调函数来获取值。让我们使用已与捆绑在一起
flask的
werkzeug.local.LocalProxy:
from werkzeug.local import LocalProxyclass ShopAreaAndStyleListAPI(Resource): @redis_hash_shop_style(key=LocalProxy(lambda: 'shop_{}_style'.format(g.city.id))) def get(self): # if not found from redis, query from mysql pass
一般来说(对于非
flask或非
werkzeug应用),我们可以使用一个类似的
LazyProxy从
ProxyTypes包。
与此无关,您还希望将
redis_hash_shop_style装饰器固定为不仅可以从获取
redis,还可以通过
f()在适当时调用wrapd来更新(或创建)陈旧(或不存在)的值。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)