Aig*_*dir 4 django postgresql docker docker-compose
我有一个带有 PostgreS 数据库的 Django 项目。我需要在 docker 容器中使用我的本地数据库。如何与docker容器共享机器的本地主机?我的 docker-compose.yml:
version: '3'
services:
web:
build: ./
network_mode: "host"
command: bash -c "python manage.py makemigrations && python manage.py migrate && python manage.py collectstatic --noinput --i rest_framework && gunicorn orion-amr.wsgi:application --bind 0.0.0.0:8000 --workers=2"
ports:
- "${webport}:8000"
- "${pgport}:${pgport}"
env_file:
- ./.env
Run Code Online (Sandbox Code Playgroud)
Django设置.py :
DATABASES = {
'default': {
'ENGINE': 'django.contrib.gis.db.backends.postgis',
'NAME': os.environ.get('pgdatabase'),
'USER': os.environ.get('pguser'),
'PASSWORD': os.environ.get('pgpassword'),
'HOST': os.environ.get('pghostname'),
'PORT': os.environ.get('pgport'),
}
}
Run Code Online (Sandbox Code Playgroud)
我加了
listen_addresses = '*'
Run Code Online (Sandbox Code Playgroud)
到postgresql.conf文件,下面是我的pg_hba.conf文件:
# TYPE DATABASE USER ADDRESS METHOD
# IPv4 local connections:
host all all 0.0.0.0/0 trust
# IPv6 local connections:
host all all ::/0 trust
# Allow replication connections from localhost, by a user with the
# replication privilege.
host replication all 127.0.0.1/32 trust
host replication all ::1/128 trust
Run Code Online (Sandbox Code Playgroud)
现在我有一个错误:
web_1 | django.db.utils.OperationalError: could not connect to server: Connection refused
web_1 | Is the server running on host "127.0.0.1" and accepting
web_1 | TCP/IP connections on port 5432?
web_1 |
Run Code Online (Sandbox Code Playgroud)
谁能帮我?请!
似乎是os.environ.get('pghostname')指向127.0.0.1哪里127.0.0.1是说这个容器,而不是主机数据库。作为错误
Is the server running on host "127.0.0.1" and accepting
Run Code Online (Sandbox Code Playgroud)
要与主机 DB 连接,您有 mac 和 window 的特殊 DNS host.docker.internal。数据库主机应该是
'HOST': "host.docker.internal"
Run Code Online (Sandbox Code Playgroud)
要与 HOST DB 连接,或者如果您使用的是 Linux,则应该是
'HOST': "HOST_IP"
Run Code Online (Sandbox Code Playgroud)
您可以从ifconfig.
| 归档时间: |
|
| 查看次数: |
361 次 |
| 最近记录: |