【发布时间】:2021-09-12 03:19:01
【问题描述】:
我有一个问题,在使用 gunicorn (gevent) 运行的 django (3.2) Web 应用程序中实现的一个 API 必须从多个 API 获取不同的价格并将这些价格存储在数据库 (Postgres 13) 中,然后再返回客户端. 我想将插入放在同一个事务中,所以如果发生意外情况,则不会插入任何内容。
我现在首先调用所有 api,每个 api 都在一个绿色线程 (gevent) 中,在它们全部返回后,我批量插入结果。
但事实证明,我真的很好奇我是否可以让不同的线程(绿色或非绿色)共享同一个事务。我看到 psycopg2 可以以非阻塞方式执行。 现在的问题是每次我在 django 中启动线程时,新线程都在新事务中。我将深入研究 django db 后端源以了解发生了什么,但也许有人可以将其清除。
Tldr;不同线程可以在同一个事务中执行查询吗?
【问题讨论】:
-
在 gunicorn (gevent) 上运行。所以我猜有些东西是由gevent修补的。不确定是否整个线程模块。我得检查一下
标签: python django postgresql multithreading gevent