django 多进程 mysql_Django 多进程操作 Mysql 时 2013: Lost connection to MySQL server during query 的问题...

本文介绍了在使用Django进行多进程操作MySQL时遇到的2013错误,即'Lost connection to MySQL server during query'。问题源于主进程与子进程共享数据库连接,主进程关闭连接后子进程无法继续操作。解决方案包括主进程不进行数据库操作,仅由子进程处理,通过锁控制并发任务,确保每个子进程独立获取和释放数据库连接。通过这种方式,成功解决了多进程环境下Django操作MySQL的连接丢失问题。
摘要由CSDN通过智能技术生成

最近在优化Django数据库操作的性能问题,由于Python的GIL限制引入了多进程,优化过程中碰到了非常奇怪的数据库连接丢失问题,导致程序终止运行

errcode is 2013, errmsg is 'Lost connection to MySQL server during query'

排查了很长时间,最后明确导致这个错误的原因跟进程的fork机制有关:fork子进程完全复制父进程的空间

原程序的逻辑是这样的:

1.主进程查询待处理任务数据集

2.然后,创建进程池,并将任务数据集交由进程池处理

也就是说:

1.主进程建立了数据库连接

2.fork子进程的时候也fork了数据库连接(可以理解数据库连接资源是一个引用复用,不确定这样描述是否准确)

3.主进程操作完成,释放了数据库连接,这时子进程在做数据库操作的时候就连接丢失了

解决方案

1.在主进程创建进程池前释放数据库连接(测试时发现不能解决问题)

2.主进程不做数据库操作,子进程做任务抢占

模拟代码

问题复现

在主进程操作数据库,随后创建进程池,并在子进程中进行数据库操作

def process_lost(key):

i = 0

while True:

if i > 5:

return

time.sleep(2)

keys = ReviewRetraceKey.objects.filter(job_id__in=[6631860103316242436]).order_by('-creat

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值