我有一个与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 cleanmvn 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: .

10-08 04:49