(2006, ‘MySQL server has gone away’) 和 失去connection的bug
定时任务太多,且频繁时,遇到了这个问题
可能是orm打开的数据库连接太多,没有及时关闭造成的
解决方法,通过装饰器,在每个有与数据库操作的函数前,加上关闭连接的装饰器。
from django.db import connections
# ref: django.db.close_old_connections
def close_old_connections():
for conn in connections.all():
conn.close_if_unusable_or_obsolete()
def handle_db_connections(func):
def func_wrapper(*args):
close_old_connections()
result = func(*args)
close_old_connections()
return result
return func_wrapper
@handle_db_connections
def orm_test():
# 数据库orm操作
pass