通过Mac OS X连接到Docker中的远程数据库

问题描述 投票:0回答:1

我在Mac OS X上,有一个docker-compose.yml

version: '3'
services:
  portalmodules:
    build:
      context: .
      dockerfile: Dockerfile
    ports:
      - 8010:8000
    links:
      - database
  database:
    image: postgres:11.2
    expose:
      - "5432"
    environment:
      - "POSTGRES_PASSWORD=12345"
      - "POSTGRES_USER=john"
      - "POSTGRES_DB=api"

我也有一个Dockerfile

FROM composer:1.8.5 as build_stage

COPY . /src
WORKDIR /src
RUN composer install


FROM alpine:3.8
RUN apk --no-cache add \
php7 \
php7-mbstring \
php7-session \
php7-openssl \
php7-tokenizer \
php7-json \
php7-pdo \
php7-pdo_pgsql \
php7-pgsql
COPY --from=build_stage /src  /src
RUN ls -al
RUN set -x \
addgroup -g 82 -S www-data \
adduser -u 82 -D -S -G www-data www-data
WORKDIR /src
RUN ls -al
RUN chmod -R 777 storage
CMD php artisan serve --host=0.0.0.0

当我运行docker-compose up时,容器似乎构建并成功启动。

但是当我尝试连接数据库时:

  • IP:localhost
  • 港口:5432
  • 联合国:约翰
  • PW:12345

我不断得到

如何进行并进一步调试?

laravel docker docker-compose dockerfile psql
1个回答
3
投票

通过在expose配置中指定端口,您只需将该端口打开到Docker网络中的其他Docker容器。它将无法从主机(OS X)连接。

您想要添加ports配置,该配置允许您将主机端口映射到容器。

database:
  image: postgres:11.2
  expose:
   - "5432"
  ports:
    - "5432:5432"
  environment:
    - "POSTGRES_PASSWORD=12345"
    - "POSTGRES_USER=john"
    - "POSTGRES_DB=api"

More information in this helpful StackOverflow Q&A.

© www.soinside.com 2019 - 2024. All rights reserved.