gpt4 book ai didi

spring - Docker Compose + Spring Boot + Postgres 连接

转载 作者:IT老高 更新时间:2023-10-28 12:47:17 27 4
gpt4 key购买 nike

我有一个与 Postgres 数据库配合使用的 Java Spring Boot 应用程序。我想对它们都使用 Docker。我最初只将 Postgres 放在 Docker 中,并且我有一个 docker-compose.yml 文件定义如下:

version: '2'
services:
db:
container_name: sample_db
image: postgres:9.5
volumes:
- sample_db:/var/lib/postgresql/data
environment:
- POSTGRES_PASSWORD=sample
- POSTGRES_USER=sample
- POSTGRES_DB=sample
- PGDATA=/var/lib/postgresql/data/pgdata
ports:
- 5432:5432

volumes:
sample_db: {}

然后,当我发出命令 sudo dockerdsudo docker-compose -f docker-compose.yml up 时,它正在启动数据库。我可以使用 pgAdmin 进行连接,例如,使用 localhost 作为服务器和端口 5432。然后,在我的 Spring Boot 应用程序中,在 application.properties 文件中,我定义了以下属性。

spring.datasource.url=jdbc:postgresql://localhost:5432/sample
spring.datasource.username=sample
spring.datasource.password=sample
spring.jpa.generate-ddl=true

此时我可以通过 Spring Suite 在本地运行我的 Spring Boot 应用程序,并且一切正常。然后,我还想将我的 Spring Boot 应用程序添加为 Docker 镜像。我首先在我的项目目录中创建了一个 Dockerfile,如下所示:

FROM java:8
EXPOSE 8080
ADD /target/manager.jar manager.jar
ENTRYPOINT ["java","-jar","manager.jar"]

然后,我进入到发出mvn clean的项目目录,接着是mvn install。接下来,发出 docker build -f Dockerfile -t manager . 后跟 docker tag 9c6b1e3f1d5e myuser/manager:latest (id 正确)。最后,我将现有的 docker-compose.yml 文件编辑为如下所示:

version: '2'
services:
web:
image: myuser/manager:latest
ports:
- 8080:8080
depends_on:
- db
db:
container_name: sample_db
image: postgres:9.5
volumes:
- sample_db:/var/lib/postgresql/data
environment:
- POSTGRES_PASSWORD=sample
- POSTGRES_USER=sample
- POSTGRES_DB=sample
- PGDATA=/var/lib/postgresql/data/pgdata
ports:
- 5432:5432

volumes:
sample_db: {}

但是,现在如果我发出 sudo docker-compose -f docker-compose.yml up 命令,数据库将再次正确启动,但我收到错误并退出 Web 应用程序部分的代码 1。问题是连接字符串。我相信我必须将其更改为其他内容,但我不知道应该是什么。我收到以下错误消息:

web_1  | 2017-06-27 22:11:54.418 ERROR 1 --- [           main] o.a.tomcat.jdbc.pool.ConnectionPool      : Unable to create initial connections of pool.
web_1 |
web_1 | 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

有什么想法吗?

最佳答案

每个容器都有自己的网络接口(interface)和自己的本地主机。所以改变 Java 指向 Postgres 的方式:

spring.datasource.url=jdbc:postgresql://localhost:5432/sample

收件人:

spring.datasource.url=jdbc:postgresql://db:5432/sample

db 将解析为正确的 Postgres IP。


奖金。使用 docker-compose,您无需手动构建图像。所以改变:

web:
image: myuser/manager:latest

收件人:

web:
build: .

关于spring - Docker Compose + Spring Boot + Postgres 连接,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44790923/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com