簡體   English   中英

Django無法在Docker設置中連接到Postgres

[英]Django can't connect to Postgres in Docker setup

我在Docker中設置了一個使用Django和Postgres的應用程序。 我無法從應用程序連接到Postgres。 我跑的時候:

  • docker-compose run web python manage.py runserver
  • docker-compose run web python manage.py migrate

我收到以下錯誤:

django.db.utils.OperationalError: could not connect to server: No such file or directory
    Is the server running locally and accepting
    connections on Unix domain socket "/var/run/postgresql/.s.PGSQL.5432"?

這是我的Dockerfile:

FROM python:2.7

ADD requirements.txt /app/requirements.txt

WORKDIR /app/

RUN pip install -r requirements.txt

我的docker-compose.yml:

version: '2'
services:
  db:
    image: postgres:9.4
    hostname: db
    environment:
      - POSTGRES_USER=postgres
      - POSTGRES_PASSWORD=postgres
      - POSTGRES_DB=postgres
    ports:
      - "5432:5432"

  web:
    build:
      context: .
      dockerfile: Dockerfile
    hostname: web
    volumes:
      - .:/app
    ports:
      - "8000:8000"
    links:
      - db
    depends_on:
      - db
    command:
      python manage.py runserver 0.0.0.0:8000

和Django中的數據庫設置:

DATABASES = {
    'default': {
        'ENGINE': 'django.db.backends.postgresql_psycopg2',
        'NAME': 'postgres',
        'USER': 'postgres',
        'HOST': 'db',
        'PORT': 5432,
    }
}

docker ps -a顯示:

e9df7e1644ce        web             "python manage.py ..."   About a minute ago   Up About a minute          0.0.0.0:8000->8000/tcp   web_1
60801d3256e4        postgres:9.4        "docker-entrypoint..."   About a minute ago   Up About a minute          0.0.0.0:5432->5432/tcp   db_1

Django v1.10.5
Docker for Mac v1.13.1
docker-compose v 1.11.1

這是日志:

原來問題是Postgres在啟動Django應用程序之前沒有完全旋轉。 在啟動Web服務器之前等待幾秒鍾就可以輕松解決這個問題。 我將我的web服務command設置為./bin/boot.sh ,該文件的內容為:

#!/bin/sh

# wait for Postgres to start
sleep 10

python manage.py migrate

python manage.py runserver 0.0.0.0:8000

編輯

這個方法可能不夠好,這取決於你的應用程序 - 大多數時候,睡眠10秒對我有效,但是postgres可能需要11秒才能啟動。 這是一個改進的bash文件,我從這個例子中獲取了一個函數。

#!/bin/bash

# wait for Postgres to start
function postgres_ready(){
python << END
import sys
import psycopg2
try:
    conn = psycopg2.connect(dbname="postgres", user="postgres", password="postgres", host="postgres")
except psycopg2.OperationalError:
    sys.exit(-1)
sys.exit(0)
END
}

until postgres_ready; do
  >&2 echo "Postgres is unavailable - sleeping"
  sleep 1
done

python manage.py migrate

gunicorn pft.wsgi:application -w 2 -b 0.0.0.0:8000 --reload

我有這個問題,這只是因為我使用的是VPN。 如果您使用sshuttle東西, sshuttle其關閉。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM