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

时间:2019-04-16 18:48:01

标签: laravel docker docker-compose dockerfile psql

我正在使用 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:本地主机
  • 端口:5432
  • 联合国:约翰
  • PW:12345

我不断得到

人们将如何进行进一步的调试?

1 个答案:

答案 0 :(得分: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.