Postgresql 在docker compose中,如何将一个容器中的应用程序连接到另一个容器中的postgres db
我是docker的初学者,也是docker作曲的新手。我正在尝试让一个项目与docker compose一起运行。当我的后端应用程序尝试连接到数据库时,出现以下错误:Postgresql 在docker compose中,如何将一个容器中的应用程序连接到另一个容器中的postgres db,postgresql,docker,docker-compose,Postgresql,Docker,Docker Compose,我是docker的初学者,也是docker作曲的新手。我正在尝试让一个项目与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 conn
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:
数据库不在Java容器的
localhost
中。您可以将Java配置指向Postgres,如下所示:db:5432
您还可以从Java容器到db的链接开始,顺序如下:
backend:
image: java
links:
- db
(...the rest...)
也许您需要等待Postgres在Java启动之前打开其端口5432(我不知道是否强制)。如果需要,常用的方法是添加wait-for-it.sh脚本(可在GitHub上获得),修改命令:
命令:/wait-for-it.sh db:5432--sh/usr/src/app/Docker/Docker……。
您还可以使用dependens\u on
要求在后端启动之前启动db。我认为在版本2以上的docker compose.yml
文件中,服务位于同一网络中,因此它们不应该被显式链接。Filtfilt,你是对的。但是表达链接会给你一些启动顺序。链接还以与依赖相同的方式表示服务之间的依赖关系,因此它们决定了服务启动的顺序。您是否应该像这样将容器端口映射到主机端口-“5432:5432”
?