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',
}
}
Ответы
Ответ 1
Это могут быть некоторые проблемы:
- PostgreSQL не работает. Проверьте его с помощью sudo
service postgresql status
-
Ваш PostgresSQl не работает на порту 5432. Вы можете проверить его набрав sudo netstat -nl | grep postgres
-
У вас что-то не так, что вы пытаетесь подключиться к вашему db, как имя пользователя, пароль или имя_базы. Убедитесь, что это то, что postgres просят вас подключить, и это имя db_name, к которому вы хотите получить доступ.
-
Проблемы с postmaster.pid в postgres. Это может произойти из-за незавершенного завершения. Это заставляет напоминать pid живым, что не позволяет запустить ваш сервер. Чтобы исправить это, вы должны:
* rm /usr/local/var/postgres/postmaster.pid
* pg_resetxlog -f /usr/local/var/postgres
После этого он должен работать должным образом, если вы создадите серверный сервер postgres
Справка в Mac OSX: Как запустить PostgreSQL-сервер в Mac OS X?
Ответ 2
Попробуйте убить все процессы postgres. Im на MAC, и это решение, которое я нашел на форуме ubuntus, действительно работает.
https://askubuntu.com/questions/547434/how-to-nicely-stop-all-postgres-processes
![введите описание изображения здесь]()
Ответ 3
Для Windows
Перейдите в панель поиска и просто напишите "Open psql
" и нажмите Enter.
После открытия экрана повторите проект django.
Ответ 4
В моем случае все было настроено правильно, и у Postgres был правильный порт, PostgreSQL работал нормально, но порт 5432 использовался совместно с phppgadmin, я мог получить доступ к phppgadmin, который дает мне веб-доступ к серверу базы данных Postgres, но мое приложение Django не работал, он вернул бы соединение отказано ошибка. поэтому я изменил номер порта в файле конфигурации phppgadmin (/etc/phppgadmin/config.inc.php) на 5433 с 5432, и все работало нормально.
Ответ 5
Перейти к экземпляру aws → группы безопасности → источник → входящий → :: 0
Ответ 6
Следующая команда работает для меня (Windows) -
pg_ctl -D "C:\Program Files\PostgreSQL\11\data" restart
Затем запустите сервер again-
python manage.py runserver