flask》》多线程并发数据安全问题 threading.local werkzeug.local.Local

python 作用域 问题

python 复制代码
x = 10          # 全局变量
def foo():
    x = 20      # 这是局部变量,与全局 x 同名但无关
    print(x)    # 输出 20
foo()
print(x)        # 输出 10(全局 x 没变)
本质:函数内有自己的局部命名空间,外部是全局命名空间。同名只是巧合,它们完全独立。
如果想在函数内修改全局变量,需要用 global 关键字。

核心目的:避免函数内部意外污染全局变量,实现代码隔离。
==================================
x = 10          # 全局变量
def foo():
   global x
    x = 20      # 这是全局变量,与全局 x 同一个
    print(x)    # 输出 20
foo()
print(x)        # 输出 20

threading.local:线程局部存储

这是多线程环境 下的数据隔离机制。每个线程访问同一个 local 对象时,看到的是属于该线程自己的数据副本

flask >>werkzeug.local.Local



协程资料

python 复制代码
# 从 werkzeug.local 导入 Local 类(比 threading.local 功能更强,支持协程等)
from werkzeug.local import Local
import threading
import time

# 创建一个 Local 对象,类似一个全局容器,每个线程/协程都能拥有独立的数据副本
local_data = Local()

def worker(worker_id):
    # 1. 在当前线程中设置自己的专属数据
    #    不同线程对同一个 local_data.user 的赋值不会互相干扰
    local_data.user = f"worker_{worker_id}"
    
    # 模拟一些耗时操作,让线程交错执行,验证数据隔离性
    time.sleep(0.1)
    
    # 2. 获取数据,验证其他线程是否干扰
    #    使用 getattr 避免属性不存在时报错(这里 user 一定存在,但演示安全获取方式)
    # getattr(object, name, default) 是 Python 内置函数,用于安全地获取对象的属性值,
    #      如果属性不存在则返回默认值(不会抛出 AttributeError)。
    # setattr(obj, 'attr', value) 等价于 obj.attr = value
    # hasattr(obj, 'attr') 检查属性是否存在,返回 bool
    # delattr(obj, 'attr') 删除属性
    #    getattr(local_data, 'user', None) 等价 local_data.user if local_data.user else none
    my_user = getattr(local_data, 'user', None)
    print(f"线程 {worker_id} 中的用户: {my_user}")

threads = []
for i in range(3):
    t = threading.Thread(target=worker, args=(i,))
    threads.append(t)
    t.start()

for t in threads:
    t.join()


线程 0 中的用户: worker_0
线程 2 中的用户: worker_2
线程 1 中的用户: worker_1

python 多线程

thread

相关推荐
lzp079122 分钟前
元数据驱动开发 - 面向对象编程思想的补充(上)
spring boot·后端·ui
明月_清风8 小时前
加密解密系统完全指南:原理剖析与 Go 实践
后端
风吹夏回8 小时前
Python 全局异常处理:从“满屏 try-except”到优雅兜底
开发语言·python
小熊Coding9 小时前
Python爬取当当网二手图书项目实战!
开发语言·爬虫·python·beautifulsoup·requests·二手图书
秋99 小时前
Java项目运行5天左右自动宕机:系统性定位与解决方案
java·开发语言·python
小江的记录本9 小时前
【JVM虚拟机】垃圾回收GC:垃圾收集器:CMS:核心原理、回收流程、优缺点、废弃原因(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·spring·面试·maven
田里的水稻10 小时前
OE_ubuntu26.04与宿主机之间复制粘贴内容
人工智能·python·机器人
冬奇Lab10 小时前
每日一个开源项目(第105篇):Twenty - 跳出 Salesforce 的圈套,定义现代开源 CRM
前端·后端·开源
jiayong2311 小时前
02 创建虚拟环境
python
旺仔来了11 小时前
不联网的Linux下部署python环境
linux·开发语言·python