我有一个Java Spring Boot应用程序,可以与Postgres数据库一起使用。我想将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 dockerd
和sudo docker-compose -f docker-compose.yml up
时,它正在启动数据库。例如,我可以使用pgAdmin
作为服务器和端口localhost
进行连接。然后,在我的Spring Boot应用程序中,在5432
文件中我定义了以下属性。
application.properties
此时我可以通过Spring Suite在本地运行我的Spring Boot应用程序,而且一切正常。然后,我想将我的Spring Boot应用程序添加为Docker镜像。我首先在项目目录中创建了一个Dockerfile,如下所示:
spring.datasource.url=jdbc:postgresql://localhost:5432/sample
spring.datasource.username=sample
spring.datasource.password=sample
spring.jpa.generate-ddl=true
然后,我进入了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 .
(ID正确)。最后,我编辑了现有的docker tag 9c6b1e3f1d5e myuser/manager:latest
文件,如下所示:
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: {}
命令,数据库会再次正确启动,但是我收到错误并退出Web应用程序部分的代码1。问题是连接字符串。我相信我必须把它改成别的东西,但我不知道应该是什么。我收到以下错误消息:
sudo docker-compose -f docker-compose.yml up
有什么想法吗?
答案 0 :(得分:18)
每个容器都有自己的网络接口和自己的localhost。所以改变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: .
答案 1 :(得分:4)
我遇到了同样的问题,我浪费了一些时间来理解和解决这个问题:
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.
我展示了所有属性,以便大家理解。
application.properties:
spring.datasource.url=jdbc:postgresql://localhost:5432/testdb
spring.datasource.driver-class-name=org.postgresql.Driver
spring.datasource.username=postgres
spring.datasource.password=postgres
spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.PostgreSQL82Dialect
spring.jpa.hibernate.ddl-auto=update
docker-compose.yml:
version: "3"
services:
springapp:
build: .
container_name: springapp
environment:
SPRING_DATASOURCE_URL: jdbc:postgresql://db:5432/testdb
ports:
- 8000:8080
restart: always
depends_on:
- db
db:
image: postgres
container_name: db
environment:
- POSTGRES_USER=postgres
- POSTGRES_PASSWORD=postgres
- POSTGRES_DB=testdb
- PGDATA=/var/lib/postgresql/data/pgdata
ports:
- 5000:5432
volumes:
- pgdata:/var/lib/postgresql/data
restart: always
volumes:
pgdata:
对于使用本地数据库启动spring应用程序,我们使用url localhost。
为了使用数据库连接到容器,我们需要在数据库服务上将“ localhost”更改为“ localhost ”,将其更改为“ db ”。
解决方案:在SPRING_DATASOURCE_URL
中添加docker-compose.yml
环境,并重写spring.datasource.url
的值以进行连接:
environment:
SPRING_DATASOURCE_URL: jdbc:postgresql://db:5432/testdb
我希望这可以帮助某人节省时间。
答案 2 :(得分:0)
您可以使用它。
version: "2"
services:
sample_db-postgresql:
image: postgres:9.5
ports:
- 5432:5432
environment:
- POSTGRES_PASSWORD=sample
- POSTGRES_USER=sample
- POSTGRES_DB=sample
volumes:
- sample_db:/var/lib/postgresql/data
volumes:
sample_db: