ol_m_lo 2021-07-26 09:54 采纳率: 60%
浏览 195
已结题

django+celery中celery使用mysql 报错中止连接

windows环境下,我在django项目中使用了celery。在使用中,长时间未操作时(大于八小时),celery操作mysql报错:<2013, lost connection to mysql server during query<[winerror 10053] 你的主机中的软件中止了一个已建立的连接>>,但是这个时候django对mysql的操作是正常的(我连接mysql使用的pymysql库),celery中就报错。

main.py

import os
import django
os.environ.setdefault('DJANGO_SETTINGS_MODULE', 'django.setting')
django.setup()
os.environ.setdefault('FORKED_BY_MULTIPROCESSING', '1')

from django.conf import settings
from celery import Celery

app = Celery('django', backend='redis://........')
app.config_from_object('celery_tasks.config')
app.autodiscover_tasks(lambda: settings.INSTALLED_APPS)
app.conf.timezone = 'Asia/Shanghai'
app.conf.update(result_expire=24*60*60)

app.autodiscover_tasks(['celery_tasks.a_task', '....'])

config.py

broker_url = 'redis:/......'

tasks.py

from project.models import Status
from celery_tasks.main import app


@app.task(name='run_exe', bind=True)
def run_exe(self, *args, **kwargs):
    # ...
    # 出问题的地方,在执行orm查询时报错(此时异步中所有操作数据库的操作都是这个错误)。
    try:
        s_objs = Status.objects.filter(id=id)
    except Exception as e:
        pass
    # ......
  • 写回答

3条回答 默认 最新

  • 唯羽 2021-07-27 16:58
    关注

    刚才说的不太对,django应该是在每个请求的进来的时候发起连接,请求结束后再断开吧。。没研究这么细过,celery应该就不是了,进程没有断那就一直保持连接了的样子

    评论

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 7月28日
  • 修改了问题 7月26日
  • 创建了问题 7月26日

悬赏问题

  • ¥20 有关区间dp的问题求解
  • ¥15 多电路系统共用电源的串扰问题
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料