在docker-compose中,如何将一个容器中的应用程序连接到另一个容器中的postgres数据库

时间:2017-05-25 01:19:10

标签: postgresql docker docker-compose

我是docker的初学者,也是docker-compose的新手。我试图用docker compose运行一个项目。当我的后端应用程序尝试连接到数据库时,我收到此错误:

org.postgresql.util.PSQLException: Connection to localhost:5432 refused. Check that the hostname and port are correct and that the postmaster is accepting TCP/IP connections.

你能看到我的撰写文件有什么问题导致它无法连接吗?

version: "3"

services:
  db:
    image: postgres
    volumes:
      - data-volume:/var/lib/db
    ports:
     - "5432"
  backup:
    image: ubuntu
    volumes:
      - data-volume:/var/lib/backup/data
  backend:
    image: java
    restart: always
    volumes:
      - data-volume:/var/lib/backup/data
      - ~/code/myCode:/usr/src/app/
    command: sh /usr/src/app/Docker/docker-setup.sh
    expose:
      - "8000"


volumes:
  data-volume:

1 个答案:

答案 0 :(得分:3)

您的数据库不在Java容器的localhost中。您可以将Java配置指向Postgres:db:5432 您还可以从Java容器到db的链接按顺序启动:

backend:
    image: java
    links:
    - db
    (...the rest...)

也许你需要等待Postgres在 Java启动之前打开它的端口5432 (我不知道它是否是强制性的)。如果需要,通常的方法是添加wait-for-it.sh脚本(在GitHub上可用),修改命令:

command: /wait-for-it.sh db:5432 -- sh /usr/src/app/Docker/docker........