【问题标题】:reconnect keyword argument on ClearDB default connection string causing errors with MySQLdbClearDB 默认连接字符串上的 reconnect 关键字参数导致 MySQLdb 错误
【发布时间】:2017-12-31 15:56:09
【问题描述】:

我将 Django 应用程序上传到 Heroku,然后使用 Heroku 文档中的以下 3 个命令配置 cleardb 插件:

heroku addons:create cleardb:ignite
heroku config | grep CLEARDB_DATABASE_URL
heroku config:set DATABASE_URL='mysql://adffdadf2341:adf4234@us-cdbr-east.cleardb.com/heroku_db?reconnect=true'

似乎没问题,应用程序正在运行(但没有数据库)。 现在我尝试运行:

$ heroku run python manage.py migrate

这是我得到的错误:

Traceback (most recent call last):
  File "manage.py", line 22, in <module>
    execute_from_command_line(sys.argv)
  File "/app/.heroku/python/lib/python3.5/site-packages/django/core/management/__init__.py", line 363, in execute_from_command_line
    utility.execute()
  File "/app/.heroku/python/lib/python3.5/site-packages/django/core/management/__init__.py", line 355, in execute
    self.fetch_command(subcommand).run_from_argv(self.argv)
  File "/app/.heroku/python/lib/python3.5/site-packages/django/core/management/base.py", line 283, in run_from_argv
    self.execute(*args, **cmd_options)
  File "/app/.heroku/python/lib/python3.5/site-packages/django/core/management/base.py", line 327, in execute
    self.check()
  File "/app/.heroku/python/lib/python3.5/site-packages/django/core/management/base.py", line 359, in check
    include_deployment_checks=include_deployment_checks,
  File "/app/.heroku/python/lib/python3.5/site-packages/django/core/management/commands/migrate.py", line 61, in _run_checks
    issues = run_checks(tags=[Tags.database])
  File "/app/.heroku/python/lib/python3.5/site-packages/django/core/checks/registry.py", line 81, in run_checks
    new_errors = check(app_configs=app_configs)
  File "/app/.heroku/python/lib/python3.5/site-packages/django/core/checks/database.py", line 10, in check_database_backends
    issues.extend(conn.validation.check(**kwargs))
  File "/app/.heroku/python/lib/python3.5/site-packages/django/db/backends/mysql/validation.py", line 9, in check
    issues.extend(self._check_sql_mode(**kwargs))
  File "/app/.heroku/python/lib/python3.5/site-packages/django/db/backends/mysql/validation.py", line 13, in _check_sql_mode
    with self.connection.cursor() as cursor:
  File "/app/.heroku/python/lib/python3.5/site-packages/django/db/backends/base/base.py", line 254, in cursor
    return self._cursor()
  File "/app/.heroku/python/lib/python3.5/site-packages/django/db/backends/base/base.py", line 229, in _cursor
    self.ensure_connection()
  File "/app/.heroku/python/lib/python3.5/site-packages/django/db/backends/base/base.py", line 213, in ensure_connection
    self.connect()
  File "/app/.heroku/python/lib/python3.5/site-packages/django/db/backends/base/base.py", line 189, in connect
    self.connection = self.get_new_connection(conn_params)
  File "/app/.heroku/python/lib/python3.5/site-packages/django/db/backends/mysql/base.py", line 274, in get_new_connection
    conn = Database.connect(**conn_params)
  File "/app/.heroku/python/lib/python3.5/site-packages/MySQLdb/__init__.py", line 86, in Connect
    return Connection(*args, **kwargs)
  File "/app/.heroku/python/lib/python3.5/site-packages/MySQLdb/connections.py", line 204, in __init__
    super(Connection, self).__init__(*args, **kwargs2)
TypeError: 'reconnect' is an invalid keyword argument for this function

问题出在哪里,我该如何解决?

【问题讨论】:

  • 尝试从 DATABASE_URL 的末尾删除“?reconnect=true”
  • 谢谢,它有效! “?reconnect=true”是什么意思?

标签: python django heroku cleardb


【解决方案1】:

从 DATABASE_URL 的末尾删除 ?reconnect=true

数据库后面的参数是MySQL服务器的参数。在这种情况下,如果连接断开,它会要求重新连接。看起来 MySQLdb 包不支持该参数。

【讨论】:

  • 再次感谢所有帮助! :) 我还有一个问题......似乎如果我等待几秒钟,我将失去连接:“(2013,'在查询期间丢失与 MySQL 服务器的连接')”。但是,如果我刷新页面,它就会起作用。你我该怎么办?我还需要调整其他配置吗?感谢您的建议! :)
  • 我在使用 MySQLdb 和 ClearDB 时遇到了完全相同的问题。这似乎是由删除 reconnect 关键字参数引起的。如果我能找到一种方法将重新连接设置为 True 而不会从 MySQLdb 触发该错误,我会在这里发布
  • @TobyWeed 我知道这不是最近写的,但你找到任何解决方案了吗?我得到了一个关于使用 SQLAlchemy 池的提示,你能确认一下吗?
  • 谁知道解决这个 2013 年丢失连接问题的方法?我一直在研究 stackoverflow、heroku 支持等,但没有运气
猜你喜欢
  • 2011-07-23
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2017-06-21
  • 1970-01-01
  • 1970-01-01
  • 2015-03-22
相关资源
最近更新 更多