django.db.utils.OperationalError Не удалось подключиться к серверу

Я не уверен, как решить эту проблему

Я понятия не имею, почему я получаю эту ошибку, когда я пытаюсь runserver:

Performing system checks...

System check identified no issues (0 silenced).
Unhandled exception in thread started by <function wrapper at 0x1085589b0>
Traceback (most recent call last):
  File "/Library/Python/2.7/site-packages/django/utils/autoreload.py", line 222, in wrapper
    fn(*args, **kwargs)
  File "/Library/Python/2.7/site-packages/django/core/management/commands/runserver.py", line 107, in inner_run
    self.check_migrations()
  File "/Library/Python/2.7/site-packages/django/core/management/commands/runserver.py", line 159, in check_migrations
    executor = MigrationExecutor(connections[DEFAULT_DB_ALIAS])
  File "/Library/Python/2.7/site-packages/django/db/migrations/executor.py", line 17, in __init__
    self.loader = MigrationLoader(self.connection)
  File "/Library/Python/2.7/site-packages/django/db/migrations/loader.py", line 49, in __init__
    self.build_graph()
  File "/Library/Python/2.7/site-packages/django/db/migrations/loader.py", line 184, in build_graph
    self.applied_migrations = recorder.applied_migrations()
  File "/Library/Python/2.7/site-packages/django/db/migrations/recorder.py", line 59, in applied_migrations
    self.ensure_schema()
  File "/Library/Python/2.7/site-packages/django/db/migrations/recorder.py", line 49, in ensure_schema
    if self.Migration._meta.db_table in self.connection.introspection.get_table_list(self.connection.cursor()):
  File "/Library/Python/2.7/site-packages/django/db/backends/__init__.py", line 165, in cursor
    cursor = self.make_debug_cursor(self._cursor())
  File "/Library/Python/2.7/site-packages/django/db/backends/__init__.py", line 138, in _cursor
    self.ensure_connection()
  File "/Library/Python/2.7/site-packages/django/db/backends/__init__.py", line 133, in ensure_connection
    self.connect()
  File "/Library/Python/2.7/site-packages/django/db/utils.py", line 94, in __exit__
    six.reraise(dj_exc_type, dj_exc_value, traceback)
  File "/Library/Python/2.7/site-packages/django/db/backends/__init__.py", line 133, in ensure_connection
    self.connect()
  File "/Library/Python/2.7/site-packages/django/db/backends/__init__.py", line 122, in connect
    self.connection = self.get_new_connection(conn_params)
  File "/Library/Python/2.7/site-packages/django/db/backends/postgresql_psycopg2/base.py", line 134, in get_new_connection
    return Database.connect(**conn_params)
  File "/Library/Python/2.7/site-packages/psycopg2/__init__.py", line 164, in connect
    conn = _connect(dsn, connection_factory=connection_factory, async=async)
django.db.utils.OperationalError: could not connect to server: Connection refused
        Is the server running on host "127.0.0.1" and accepting
        TCP/IP connections on port 5432?

Когда я пытаюсь подключиться к postgres:

psql: could not connect to server: No such file or directory
        Is the server running locally and accepting
        connections on Unix domain socket "/tmp/.s.PGSQL.5432"?

settings.py:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.postgresql_psycopg2',
        'NAME': 'beerad',
        'USER': 'bli1',
        'PASSWORD': '',
        'HOST': '127.0.0.1',
        'PORT': '5432',
    }
}

15 ответов

Решение

Это могут быть некоторые проблемы:

  1. PostgreSQL не работает. Проверьте это с помощью sudo service postgresql status
  2. Ваш PostgresSQl не работает на порту 5432. Вы можете проверить его, набрав sudo netstat -nl | grep postgres

  3. Вы что-то не так пытаетесь подключиться к вашей базе данных, как имя пользователя, пароль или имя базы данных. Убедитесь, что это то, что postgres просит вас подключить, и это db_name, к которому вы хотите получить доступ.

  4. Проблемы с postmaster.pid в postgres. Это может произойти из-за неправильного завершения работы. Это напоминает живой pid, который не позволяет запустить ваш сервер. Чтобы исправить это, вы должны:

     * rm /usr/local/var/postgres/postmaster.pid 
     * pg_resetxlog -f /usr/local/var/postgres
    

    После этого он должен работать правильно, если вы делаете runserver из postgres

Помощь в Mac OSX: Как запустить сервер PostgreSQL в Mac OS X?

Для Windows

Зайдите в панель поиска и просто напишитеOpen psql"и нажмите Enter.

После того, как экран открыт, перезапустите проект django.

Попробуйте убить все процессы postgres. Я нахожусь на MAC, и это решение, которое я нашел на форуме Ubuntus, действительно работает.

https://askubuntu.com/questions/547434/how-to-nicely-stop-all-postgres-processes введите описание изображения здесь

В моем случае все было настроено правильно, и у Postgres был правильный порт, PostgreSQL работал нормально, но порт 5432 использовался совместно с phppgadmin, я мог получить доступ к phppgadmin, который дает мне веб-доступ к серверу базы данных Postgres, но мое приложение Django не работало, это вернул бы Соединение отказало ошибку. поэтому я изменил номер порта в файле конфигурации phppgadmin (/etc/phppgadmin/config.inc.php) на 5433 с 5432, и все работало нормально.

В MacOS я остановил и перезапустил postgresql в соответствии с советом, приведенным в этом ответе StackExchange:https://dba.stackexchange.com/a/171580/182403

brew services stop postgresql
rm /usr/local/var/postgres/postmaster.pid # adjust path accordingly to your install
brew services start postgresql

Я была такая же проблема. Эта ошибка возникает, когда было выполнено неправильное завершение работы системы. У меня M1, и я установил PostgreSQL через Homebrew.

Я попытался запустить PostgreSQL после получения ошибки, идентичной вашей, используя brew services start postgresql, но я получил эту ошибку:

      Bootstrap failed: 5: Input/output error
Try re-running the command as root for richer errors.
Error: Failure while executing; `/bin/launchctl bootstrap gui/501 /Users/adithraghav/Library/LaunchAgents/homebrew.mxcl.postgresql.plist` exited with 5.

Итак, я попытался остановить работающий экземпляр и запустить его снова с помощью brew services restart postgresql.

Эта строка дала мне следующий вывод:

      Stopping `postgresql`... (might take a while)
==> Successfully stopped `postgresql` (label: homebrew.mxcl.postgresql)
==> Successfully started `postgresql` (label: homebrew.mxcl.postgresql)

Я проверил порт, на котором работал PostgreSQL. sudo netstat -nl | grep postgres, но не получил никакого вывода.

Поэтому я удалил существующий postmaster.pidфайл с этим:

      rm /opt/homebrew/var/postgres/postmaster.pid 

ПРИМЕЧАНИЕ. Если вы не используете M1 Mac, вам нужно запустить rm /usr/local/var/postgres/postmaster.pid.

Затем я побежал pg_resetwal -f /opt/homebrew/var/postgresдля сброса журнала упреждающей записи. (ПРИМЕЧАНИЕ. Начиная с Postgres 10 и выше, pg_resetxlogбыл переименован в pg_resetwal).

В настоящее время, python3 manage.py runserverработает без нареканий :)

Перезапуск сервера решил проблему с моей стороны.

В папке проекта/settings.py в разделе DATABASE- HOSTнастройки вы должны использовать локальный IP-адрес (127.0.0.1), а не ваш общедоступный IP-адрес.

Правильный

      DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.postgresql',
        'NAME': 'yourdb',
        'USER': 'youruser',
        'PASSWORD': 'yourpass',
        'HOST': '127.0.0.1',
        'PORT': '5432'
    }
}

Неправильно

      DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.postgresql',
        'NAME': 'yourdb',
        'USER': 'youruser',
        'PASSWORD': 'yourpass',
        'HOST': '188.252.196.234 ',
        'PORT': '5432'
    }
}

Если вы видите эту ошибку при использовании PostgresSQL из Google Cloud, выполните все конфигурации, указанные в https://cloud.google.com/python/django/flexible-environment flexible-environment#macos-64- bit

Также разделите конфигурацию HOST, как показано ниже

БАЗЫ ДАННЫХ ['default']['HOST'] = '/cloudsql/' if os.getenv('GAE_INSTANCE'): pass else: DATABASES['default']['HOST'] = '127.0.0.1'

Это помогает устранить эту ошибку.

У меня работает следующая команда (Windows)-

pg_ctl -D "C:\Program Files\PostgreSQL\11\data" restart

Затем снова запустите сервер -

python manage.py runserver

Одна проблема, которую я нашел общей для Django/Postgres (особенно с Docker), заключается в том, что ваше веб-приложение Django может запускаться до запуска вашего сервера Postgres. Если другие решения не работают, попробуйте перезапустить приложение Django после запуска. С Docker команда будет docker restart <web-app container name>

Вы должны включить адреса прослушивания, если вы используете удаленную базу данных.

      cd /etc/postgresql/12.x/main/

открыть файл с именем postgresql.conf

      sudo nano postgresql.conf

добавить эту строку в этот файл

      listen_addresses = '*'

затем откройте файл с именем pg_hba.conf

      sudo nano pg_hba.conf

и добавьте эту строку в этот файл

      host  all  all 0.0.0.0/0 md5

перезагрузите свой сервер

      sudo /etc/init.d/postgresql restart

Возможно, вы не подключаетесь к нужной базе данных. Если вы используете Docker, убедитесь, что вы используете 5432 как порт за пределами образа.

например:

db: image: postgres: 12.0-alpinevolume: - postgres_data: / var / lib / postgresql / data / env_file:- ./postgres/.env ports: - 5432 : 5432

Перейдите в экземпляр aws -> группы безопасности -> источник -> входящие ->::0

проверьте, используется ли порт. Я исправил остановку службы Postgre в Windows из Services.msc.

Другие вопросы по тегам