我有一个 Java Spring Boot 应用程序,它与 Postgres 数据库配合使用。我想对它们两个都使用 Docker。我最初只将 Postgres 放入 Docker,并且我有一个 docker-compose.yml 文件定义 l...
我有一个 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
作为服务器和端口 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
有什么想法吗?
我遇到了同样的问题,并且花了一些时间来理解和解决这个问题:
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
我希望这可以帮助某些人节省时间。