繁体   English   中英

在docker上运行的mysql容器无法与spring boot java api服务连接

[英]mysql container which is running on docker can't able to connect with spring boot java api service

  1. 我有一个在 docker 容器上运行的 mysql。 使用此命令拉取和运行容器

  2. $ docker container run --name cloud --network employee -e MYSQL_ROOT_PASSWORD=root -e MYSQL_DATABASE=bootdb -d mysql:5.7

  3. 本地的spring boot应用程序-我正在尝试在java应用程序和mysql容器之间建立连接:

配置属性

spring.datasource.url=jdbc:mysql://cloud/bootdb?serverTimezone=UTC&characterEncoding=UTF-8&useUnicode=true&allowPublicKeyRetrieval=true&useSSL=false
spring.datasource.username=root
spring.datasource.password=root
spring.datasource.platform=mysql
spring.datasource.initialization-mode=always
spring.jpa.hibernate.ddl-auto = create
spring.datasource.driverClassName=com.mysql.jdbc.Driver
spring.jpa.properties.hibernate.dialect = org.hibernate.dialect.MySQLDialect

错误:

  1. 引起:java.net.UnknownHostException:云
  2. 引起:com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure 最后一个数据包成功发送到服务器是 0 毫秒前。 驱动程序没有收到来自服务器的任何数据包。

尽管我已经通过将 mysql 连接器版本和 mysql 容器版本更改为相同的方式来构建该应用程序。 无法成功。 ——

pom文件配置-

  1. spring-boot-starter-data-jpa
  2. mysql-connector-java - 版本 5.1.46,docker mysql:5

当您说 - Spring Boot 应用程序正在本地运行时 - 我认为它在 docker 之外运行。
尝试以下选项

步骤1:再次创建mysql容器,暴露端口:3306

docker run --name cloud --network employee -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root -e MYSQL_DATABASE=bootdb -d mysql:5.7

步骤 2:使用 mysql 验证是否在暴露的端口上运行并且您可以访问它。 从 MY-SQL GUI 工具中获取帮助。

Step3:更新spring-boot配置文件。
spring.datasource.url=jdbc:mysql://localhost:3306/bootdb?serverTimezone=UTC&characterEncoding=UTF-8&useUnicode=true&allowPublicKeyRetrieval=true&useSSL=false

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM