如何与 docker 共享本地 Postgres 数据库?

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)

谁能帮我?请!

Adi*_*iii 5

似乎是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.