美文网首页
Django 项目部署上线后,数据库连接数太多,抛出too ma

Django 项目部署上线后,数据库连接数太多,抛出too ma

作者: z小志 | 来源:发表于2019-04-27 22:15 被阅读0次

    在数据库中,有一个参数 CONN_MAX_AGE , 它用来配置 Django 跟数据库的持久化连接。这一项的默认值是0。 Django 中数据库连接的逻辑是,每一个请求结束都会关闭当前的数据库连接。这意味着每来一个新的请求, Django 都会创建一个新的数据库连接。

    当配置此项的值时,需要根据参考数据库的 wait_timeout 配置,建议不要大于 wait_timeout 。此外此项还有 None。如果配置为 None,就意味着不限制连接时长。

    如果没有配置 CONN_MAX_AGE 就会出现数据库连接数太多,抛出 too many connections 错误的问题,原因就是上面所说的,所以当并发访问量过大来不及关闭连接时,会导致连接数不断增多。

    但是需要注意的是,如果你采用多线程的方式部署项目,最好不要配置 CONN_MAX_AGE。因为如果每一个请求都会使用一个新的线程来处理的,那么每个持久化的连接就达不到复用的目的。另外一个经验就是,如果使用gevent 作为worker来运行项目的话,那么也建议不配置 CONN_MAX_AGE。因为 gevent 会给 Python 的 thread(线程模块)动态打补丁(patch),这回导致数据库连接无法复用。

    附 配置正式的setting mysql数据库

    DATABASES = {
        'default': {
            'ENGINE': 'django.db.backends.mysql',
            'NAME': 'xxx',
            'USER': 'xxx',
            'PASSWORD': 'xxx',
            'HOST': 'xxx',
            'PORT': '3306',
            'CONN_MAX_AGE': 5*60,
        }
    }
    

    相关文章

      网友评论

          本文标题:Django 项目部署上线后,数据库连接数太多,抛出too ma

          本文链接:https://www.haomeiwen.com/subject/xpmlnqtx.html