问题 将Django和Postgresql与Docker链接起来


我有两个Docker容器。第一个是Postgresql容器,我使用以下命令运行。

sudo docker run -v /home/mpmsp/project/ezdict/postgresql/data:/var/lib/postgresql/data -p 127.0.0.1:5432:5432  -name my-postgres -d postgres

它基于 官方形象 它工作得很好,我可以从主机连接到Postgresql。

第二个容器是我的Django应用程序的容器。使用以下Dockerfile构建映像(基于 这个图片):

FROM python:3-onbuild
EXPOSE 8000 5432
CMD ["/bin/bash"]

然后我使用以下命令运行此容器

sudo docker run --link my-postgres:my-postgres -v /home/mpmsp/project/ezdict/ezbkend:/usr/src/app -name my-app -i -t my-app

docker ps输出显示容器已链接

NAMES
my-app/my-postgres, my-postgres

但是,当我转到localhost:8000时,我看到Django的错误页面,输出如下

OperationalError at /api-auth/login/
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?
Request Method: GET
Request URL:    http://127.0.0.1:8000/api-auth/login/
Django Version: 1.6.4
Exception Type: OperationalError
Exception Value:    
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?
Exception Location: /usr/local/lib/python3.4/site-packages/psycopg2/__init__.py in     connect, line 164
Python Executable:  /usr/local/bin/python
Python Version: 3.4.1
Python Path:    
['/usr/src/app',
 '/usr/local/lib/python34.zip',
 '/usr/local/lib/python3.4',
 '/usr/local/lib/python3.4/plat-linux',
 '/usr/local/lib/python3.4/lib-dynload',
 '/root/.local/lib/python3.4/site-packages',
 '/usr/local/lib/python3.4/site-packages']
Server time:    Птн, 10 Окт 2014 12:07:07 +0400

应用程序的settings.py

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

如何进行链接工作?提前致谢


12607
2017-10-10 08:30


起源



答案:


Dockerfile 对于你的Django图像不应该暴露端口 5432 因为没有Postgresql服务器将在从该映像创建的任何容器中运行:

FROM python:3-onbuild
EXPOSE 8000
CMD ["/bin/bash"]

然后在运行连接它的Django容器时

--link my-postgres:my-postgres

您的数据库设置不正确。

在Django容器中:127.0.0.1指的是没有运行任何侦听端口5432的服务的Django容器。

所以你的settings.py文件应该是:

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

在运行Django容器时:

sudo docker run --link my-postgres:db -v /home/mpmsp/project/ezdict/ezbkend:/usr/src/app -name my-app -i -t my-app 

然后你的 settings.py 文件必须是:

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

14
2017-10-10 09:45



什么是db同步/迁移?我意识到我无法在构建时链接postgres容器但我需要在运行django服务器之前以某种方式进行syncdb迁移。 - syabro
所以第二个参数(在冒号之后)中 --link my-postgres:[2nd arg] 成为的价值 HOST 关键在于 default  关于django的设置 DATABASES? - pkaramol
是的,语法是 --link <a container name>:<alias> - Thomasleveil


答案:


Dockerfile 对于你的Django图像不应该暴露端口 5432 因为没有Postgresql服务器将在从该映像创建的任何容器中运行:

FROM python:3-onbuild
EXPOSE 8000
CMD ["/bin/bash"]

然后在运行连接它的Django容器时

--link my-postgres:my-postgres

您的数据库设置不正确。

在Django容器中:127.0.0.1指的是没有运行任何侦听端口5432的服务的Django容器。

所以你的settings.py文件应该是:

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

在运行Django容器时:

sudo docker run --link my-postgres:db -v /home/mpmsp/project/ezdict/ezbkend:/usr/src/app -name my-app -i -t my-app 

然后你的 settings.py 文件必须是:

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

14
2017-10-10 09:45



什么是db同步/迁移?我意识到我无法在构建时链接postgres容器但我需要在运行django服务器之前以某种方式进行syncdb迁移。 - syabro
所以第二个参数(在冒号之后)中 --link my-postgres:[2nd arg] 成为的价值 HOST 关键在于 default  关于django的设置 DATABASES? - pkaramol
是的,语法是 --link <a container name>:<alias> - Thomasleveil


只有在db和django容器构建并启动之后,syncdb才有效,然后您可以使用fig / docker-compose / docker手动运行syncdb命令。 我正在考虑创建一个AT作业,让容器运行syncdb本身(并在syncdb之后创建一个admin用户 - 用于创建必要的表)


0
2018-05-23 18:00