8wDlpd.png
8wDFp9.png
8wDEOx.png
8wDMfH.png
8wDKte.png

Docker Compose + Spring Boot + Postgres 连接

Amaresh Maity 2月前

99 0

我有一个 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

有什么想法吗?

帖子版权声明 1、本帖标题:Docker Compose + Spring Boot + Postgres 连接
    本站网址:http://xjnalaquan.com/
2、本网站的资源部分来源于网络,如有侵权,请联系站长进行删除处理。
3、会员发帖仅代表会员个人观点,并不代表本站赞同其观点和对其真实性负责。
4、本站一律禁止以任何方式发布或转载任何违法的相关信息,访客发现请向站长举报
5、站长邮箱:yeweds@126.com 除非注明,本帖由Amaresh Maity在本站《rest》版块原创发布, 转载请注明出处!
最新回复 (0)
  • 我创建了一个使用 Spring Boot 2 + Docker Compose 和 Postgresql 的演示项目,

  • 每个容器都有自己的网络接口和本地主机。因此,请更改 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: .
    
  • 我不明白的一件事是,我在我的应用程序中使用 JPA,为了构建 spring-boot 应用程序,它需要连接到我的数据库,如果我的 postgre docker 没有运行,我就无法做到这一点,对吗?所以基本上,使用配置为连接到 dockerized postgre db 的类似应用程序属性,我首先无法构建我的应用程序...

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

    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
    

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

  • 我不知道环境变量会覆盖 app.properties 中的内容。谢谢 Alexander!

  • 你可以用这个。

    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:
    
  • 您可以使用 ENV 变量来更改 docker-compose 中的数据库地址。
    Dockerfile

    FROM java:8
    EXPOSE 8080
    ENV POSTGRES localhost
    ADD /target/manager.jar manager.jar
    ENTRYPOINT exec java $JAVA_OPTS -jar manager.jar --spring.datasource.url=jdbc:postgresql://$POSTGRES:5432/sample
    

    docker-compose

    container_name: springapp
    environment:
     - POSTGRES=db
    
返回
作者最近主题: