我是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:
答案 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........