psycopg2.OperationalError: FATAL: извините, слишком много клиентов уже на герою

Я попытался перенести мое приложение Flask на heroku, и мое приложение использует Postgres в качестве базы данных. Тем не менее, когда я попытался перенести db на heroku с помощью этой команды

heroku run python manage.py db init --app app

Это дает ошибку «слишком много клиентов» как для psycopg2, так и для sqlalchchemy.

Running python manage.py db migrate on ⬢ petscom... up, run.5707 (Hobby)
Traceback (most recent call last):
  File "/app/.heroku/python/lib/python3.6/site-packages/sqlalchemy/engine/base.py", line 2285, in _wrap_pool_connect
    return fn()
  File "/app/.heroku/python/lib/python3.6/site-packages/sqlalchemy/pool/base.py", line 303, in unique_connection
    return _ConnectionFairy._checkout(self)
  File "/app/.heroku/python/lib/python3.6/site-packages/sqlalchemy/pool/base.py", line 773, in _checkout
    fairy = _ConnectionRecord.checkout(pool)
  File "/app/.heroku/python/lib/python3.6/site-packages/sqlalchemy/pool/base.py", line 492, in checkout
    rec = pool._do_get()
  File "/app/.heroku/python/lib/python3.6/site-packages/sqlalchemy/pool/impl.py", line 238, in _do_get
    return self._create_connection()
  File "/app/.heroku/python/lib/python3.6/site-packages/sqlalchemy/pool/base.py", line 308, in _create_connection
    return _ConnectionRecord(self)
  File "/app/.heroku/python/lib/python3.6/site-packages/sqlalchemy/pool/base.py", line 437, in __init__
    self.__connect(first_connect_check=True)
  File "/app/.heroku/python/lib/python3.6/site-packages/sqlalchemy/pool/base.py", line 657, in __connect
    pool.logger.debug("Error on connect(): %s", e)
  File "/app/.heroku/python/lib/python3.6/site-packages/sqlalchemy/util/langhelpers.py", line 69, in __exit__
    exc_value, with_traceback=exc_tb,
  File "/app/.heroku/python/lib/python3.6/site-packages/sqlalchemy/util/compat.py", line 178, in raise_
    raise exception
  File "/app/.heroku/python/lib/python3.6/site-packages/sqlalchemy/pool/base.py", line 652, in __connect
    connection = pool._invoke_creator(self)
  File "/app/.heroku/python/lib/python3.6/site-packages/sqlalchemy/engine/strategies.py", line 114, in connect
    return dialect.connect(*cargs, **cparams)
  File "/app/.heroku/python/lib/python3.6/site-packages/sqlalchemy/engine/default.py", line 488, in connect
    return self.dbapi.connect(*cargs, **cparams)
  File "/app/.heroku/python/lib/python3.6/site-packages/psycopg2/__init__.py", line 126, in connect
    conn = _connect(dsn, connection_factory=connection_factory, **kwasync)
psycopg2.OperationalError: FATAL:  sorry, too many clients already
FATAL:  sorry, too many clients already

Немного погуглив, я попробовал:

  1. геройку пг: killall
  2. перезагрузка героку Ни одна из тех работ .....

А я проверил героку pg, показывает 0/20 подключений ...... введите описание изображения здесь

Некоторые говорят, что не помещайте соединение с БД в цикл, но я должен проверить, находятся ли некоторые данные в БД. Вот мой код:

try:
        connection = psycopg2.connect(user="postgres",
                                      password="pass",
                                      host="127.0.0.1",
                                      port="5432",
                                      database="pets")

        cursor = connection.cursor()

        select_all = "select * from pets"
        cursor.execute(select_all)

        # Check if api data in db and save to db
        for index in range(len(myData)):
            # if not exist in db => save to db
            key = myData[index]["animal_id"]
            exists = check_exists(key, cursor)
            if(exists):
                pass
            else:
                doSomething()

Я могу подключиться к моей локальной базе данных postgres, но не к базе данных на heroku. Как я могу справиться с этой проблемой? Любой совет поможет :) Спасибо!

Всего 1 ответ


У меня была аналогичная проблема. Мне удалось это исправить, установив SQLALCHEMY_TRACK_MODIFICATIONS=False в среде, уничтожив базу данных и создав новую.

Вы можете уничтожить его, перейдя по адресу https://data.heroku.com/datastores , открыв базу данных, перейдя в Настройки и выбрав «Уничтожить базу данных».

Затем предоставьте новый, как обычно.