![](/img/trans.png)
[英]not able to connect mysql docker container from spring boot docker container
[英]mysql container which is running on docker can't able to connect with spring boot java api service
我有一个在 docker 容器上运行的 mysql。 使用此命令拉取和运行容器
$ docker container run --name cloud --network employee -e MYSQL_ROOT_PASSWORD=root -e MYSQL_DATABASE=bootdb -d mysql:5.7
本地的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
错误:
尽管我已经通过将 mysql 连接器版本和 mysql 容器版本更改为相同的方式来构建该应用程序。 无法成功。 ——
pom文件配置-
当您说 - 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.