Local
Local 是什么
根据 官方文档 的介绍,local是提供了线程隔离的数据访问方式,类似于python中的 thread locals。可以理解为存在一个全局的数据,不同线程可以读取和修改它。不同线程之间是彼此隔离的。比如存在一个thread local的数组arr,在线程1往数组arr添加了一个数据,在线程1中读取时可以看到数组中存在一个数据,但是在线程2中读取时看到的数组arr依旧为空。这样带来的好处是很明显的,多线程之间考虑其他线程带来的影响,从而安全地读取和修改数据。
原生thread locals缺陷
- 不支持其他类型的并发访问,比如协程之间的隔离就没有支持;
- WSGI不保证每个请求不会共用线程,如果后面请求复用的前面请求的线程,那么就可以获取到前面请求的数据,请求之间的数据隔离无法得到支持;
Local 实现
为了实现线程隔离的数据访问,一种比较显而易见的方式就是构建一个dict,根据每个线程的id去创建独立的数据,当访问数据时,根据当前线程的id进行访问,每个线程访问自己的数据即可。这样就实现了线程隔离的数据访问。
class Local(object):
__slots__ = ('__storage__', '__ident_func__')
def __init__(self):
object.__setattr__(self, '__storage__', {})
object.__setattr__(self, '__ident_func__', get_ident)
# 获取proxy作为名字构建LocalProxy对象
def __call__(self, proxy):
return LocalProxy(self, proxy)
# 移除当前线程数据
def __release_local__(self):
self.__storage__.pop(self.__ident_func__(), None)
# 获取name对应的值
def __getattr__(self, name):
try:
return self.__storage__[self.__ident_func__()][name]
except KeyError:
raise AttributeError(name)
# 将name与