Docker Compose + Spring Boot + Postgres连接

typ*_*pos 11 postgresql spring docker dockerfile docker-compose

我有一个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: {}
Run Code Online (Sandbox Code Playgroud)

然后,当我发出的命令,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
Run Code Online (Sandbox Code Playgroud)

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

FROM java:8
EXPOSE 8080
ADD /target/manager.jar manager.jar
ENTRYPOINT ["java","-jar","manager.jar"]
Run Code Online (Sandbox Code Playgroud)

然后,我进入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: {}
Run Code Online (Sandbox Code Playgroud)

但是,现在如果我发出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
Run Code Online (Sandbox Code Playgroud)

有任何想法吗?

Rob*_*ert 19

每个容器都有自己的网络接口和自己的localhost.所以改变Java指向Postgres的方式:

spring.datasource.url=jdbc:postgresql://localhost:5432/sample
Run Code Online (Sandbox Code Playgroud)

至:

spring.datasource.url=jdbc:postgresql://db:5432/sample
Run Code Online (Sandbox Code Playgroud)

db 将解决适当的Postgres IP.


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

web:
  image: myuser/manager:latest
Run Code Online (Sandbox Code Playgroud)

至:

web:
  build: .
Run Code Online (Sandbox Code Playgroud)


Ale*_*hko 13

我遇到了同样的问题,我花了一些时间来理解和解决这个问题:

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.
Run Code Online (Sandbox Code Playgroud)

我展示了所有的属性,以便每个人都理解。
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
Run Code Online (Sandbox Code Playgroud)

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:
Run Code Online (Sandbox Code Playgroud)

为了使用本地数据库启动 spring 应用程序,我们使用 url localhost。
为了连接到带有数据库的容器,我们需要更改数据库服务上的“localhost”,在我的例子中将“ localhost ”更改为“ db ”。

解决方案:添加SPRING_DATASOURCE_URL环境并docker-compose.yml重写spring.datasource.url连接值:

  environment:
    SPRING_DATASOURCE_URL: jdbc:postgresql://db:5432/testdb
Run Code Online (Sandbox Code Playgroud)

我希望这可以帮助某人节省时间。