Docker Compose + Spring Boot + Postgres 连接
php小编西瓜今天为大家带来一篇关于如何使用Docker Compose连接Spring Boot和Postgres的教程。Docker Compose是一个用于定义和运行多容器Docker应用程序的工具,而Spring Boot则是一个用于构建Java应用程序的框架,Postgres则是一个功能强大的关系数据库。通过结合使用这三者,我们可以轻松地搭建一个包含Spring Boot应用程序和Postgres数据库的开发环境。本教程将带你一步步学习如何配置和连接这三者,让你能够快速开始开发你的应用程序。
问题内容
我有一个可与 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 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 是正确的)。最后,我编辑了现有的 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
有什么想法吗?
解决方法
每个容器都有自己的网络接口和自己的本地主机。因此改变 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: .
我遇到了同样的问题,我花了一些时间来理解和解决这个问题:
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”。
解决方案:在docker-compose.yml
中添加SPRING_DATASOURCE_URL
环境,重写spring.datasource.url
中添加SPRING_DATASOURCE_URL
环境,重写spring.datasource.url
连接值:
environment: SPRING_DATASOURCE_URL: jdbc:postgresql://db:5432/testdb
我希望这可以帮助人们节省时间。
以上是Docker Compose + Spring Boot + Postgres 连接的详细内容。更多信息请关注PHP中文网其他相关文章!

热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

记事本++7.3.1
好用且免费的代码编辑器

SublimeText3汉化版
中文版,非常好用

禅工作室 13.0.1
功能强大的PHP集成开发环境

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)

热门话题

Java模拟器是一种能够在计算机或设备上运行Java应用程序的软件。它可以模拟Java虚拟机并执行Java字节码,使用户能够在不同平台上运行Java程序。Java模拟器在软件开发、学习和测试等方面有着广泛的应用。本文将介绍五款好用且实用的Java模拟器,它们能够满足不同用户的需求,帮助用户更加高效地开发和运行Java程序。第一款模拟器是Eclipse。Ecl

log4j配置文件的常见问题及解决方案在Java应用程序的开发过程中,日志是一项非常重要的功能。而log4j是Java中一个广泛使用的日志框架。它通过配置文件来定义日志的输出方式,可以非常方便地控制日志的级别和输出位置。然而,有时候在配置log4j时会遇到一些问题,本文将介绍一些常见的问题及其解决方案,并附上具体的代码示例。问题一:日志文件没有生成解决方案:

Java是一种功能强大的编程语言,使用户能够创建广泛的应用程序,例如构建游戏、创建Web应用程序和设计嵌入式系统。Debian12是一个强大的新发布的基于Linux的操作系统,为Java应用程序的蓬勃发展提供了稳定可靠的基础。与Java和Debian系统一起,您可以打开一个充满可能性和创新的世界,这肯定可以帮助人们很多。只有在您的Debian系统上安装了Java才能做到这一点。在本指南中,您将了解:如何在Debian12上安装Java如何在Debian12上安装Java如何从Debian12中删

JUnit单元测试框架是一个广泛使用的工具,主要优点包括自动化测试、快速反馈、提高代码质量和可移植性。但它也有局限性,包括范围有限、维护成本、依赖性、内存消耗和缺乏持续集成支持。对于Java应用程序的单元测试,JUnit是一个强大的框架,提供了许多好处,但使用时需要考虑其局限性。

Oracle是一家全球知名的数据库管理系统提供商,其API(ApplicationProgrammingInterface,应用程序接口)是一种强大的工具,可帮助开发人员轻松地与Oracle数据库进行交互和集成。在本文中,我们将深入探讨OracleAPI的使用指南,向读者展示如何在开发过程中利用数据接口技术,同时提供具体的代码示例。1.Oracle

IDEA(IntelliJIDEA)是一款强大的集成开发环境,可以帮助开发人员快速高效地开发各种Java应用程序。在Java项目开发中,使用Maven作为项目管理工具能够帮助我们更好地管理依赖库、构建项目等。本文将详细介绍如何在IDEA中创建一个Maven项目的基本步骤,同时提供具体的代码示例。步骤一:打开IDEA并创建新项目打开IntelliJIDEA

什么是JMX?JMX(Java监控和管理)是一个标准框架,允许您监控和管理Java应用程序及其资源。它提供了一个统一的api来访问和操作应用程序的元数据和性能属性。MBean:管理BeanMBean(管理Bean)是JMX中的核心概念,它封装了应用程序的一部分,可以被监控和管理。MBean具有属性(可读或可写)和操作(方法),用于访问应用程序的状态和执行操作。MXBean:管理扩展BeanMXBean是MBean的扩展,它提供了更高级的监控和管理功能。MXBean由JMX规范定义,并具有预定义的

如何用java连接到mysql数据库?当我尝试时,我得到java.sql.sqlexception:nosuitabledriverfoundforjdbc:mysql://database/tableatjava.sql.drivermanager.getconnection(drivermanager.java:689)atjava.sql.drivermanager.getconnection(drivermanager.java:247)或