Аргумент ключевого слова reconnect в строке подключения ClearDB по умолчанию, вызывающий ошибки с MySQLdb

Я загрузил приложение Django в Heroku, а затем предоставил надстройку cleardb, используя эти 3 команды из документации Heroku:

heroku addons:create cleardb:ignite
heroku config | grep CLEARDB_DATABASE_URL
heroku config:set DATABASE_URL='mysql://adffdadf2341:[email protected]/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

Откуда берется проблема и как ее исправить?


person s_s    schedule 25.07.2017    source источник
comment
Попробуйте удалить ?reconnect=true в конце DATABASE_URL.   -  person jastr    schedule 25.07.2017
comment
Спасибо, это работает! что означает ?reconnect=true?   -  person s_s    schedule 25.07.2017


Ответы (1)


Удалите ?reconnect=true из конца DATABASE_URL

Параметры после базы данных являются аргументами для сервера MySQL. В этом случае он просит переподключиться, если соединение прервано. Похоже, что пакет MySQLdb не поддерживает этот аргумент.

person jastr    schedule 25.07.2017
comment
Еще раз спасибо всем за помощь! :) У меня есть еще один вопрос... Кажется, если я подожду несколько секунд, я потеряю соединение: (2013, «Потеряно соединение с сервером MySQL во время запроса»). Но если обновить страницу, то все работает. Ты что мне делать? есть ли какие-либо другие конфигурации, которые мне нужно настроить? Ценю ваш совет! :) - person s_s; 26.07.2017
comment
У меня точно такая же проблема с использованием MySQLdb и ClearDB. Похоже, что это вызвано удалением аргумента ключевого слова reconnect. Я опубликую здесь, если смогу найти способ установить повторное подключение в True, не вызывая эту ошибку из MySQLdb. - person Toby Weed; 26.06.2018
comment
@TobyWeed Я знаю, что это не было написано в последнее время, но вы нашли какое-нибудь решение? Я получил подсказку об использовании пула SQLAlchemy, можете ли вы подтвердить и это? - person MattSom; 03.11.2019
comment
Кто-нибудь знает решение этой проблемы с потерей связи в 2013 году? Я копался во всем stackoverflow, поддержке heroku и т. Д., И мне не повезло. - person Rafael Santos; 08.06.2021