Django开发定时任务遇到(2006, ‘MySQL server has gone away’)的bug

(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

你可能感兴趣的:(Django开发定时任务遇到(2006, ‘MySQL server has gone away’)的bug)