【问题标题】:Unable to conect SpringBoot to MySql using Docker compose无法使用 Docker compose 将 Spring Boot 连接到 MySql
【发布时间】:2020-06-06 15:25:34
【问题描述】:

我创建了一个 docker compose 文件,用于将 MySql 连接到 SpringBoot 应用程序。但我得到这个错误:

com.mysql.jdbc.exceptions.jdbc4.CommunicationsException: Communications link failure

The last packet sent successfully to the server was 0 milliseconds ago. The driver has not received any packets from the server.
   at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) ~[na:1.8.0_242]
   at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62) ~[na:1.8.0_242]
   at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45) ~[na:1.8.0_242]
   at java.lang.reflect.Constructor.newInstance(Constructor.java:423) ~[na:1.8.0_242]
   at com.mysql.jdbc.Util.handleNewInstance(Util.java:425) ~[mysql-connector-java-5.1.46.jar!/:5.1.46]
   at com.mysql.jdbc.SQLError.createCommunicationsException(SQLError.java:990) ~[mysql-connector-java-5.1.46.jar!/:5.1.46]
   at com.mysql.jdbc.MysqlIO.<init>(MysqlIO.java:342) ~[mysql-connector-java-5.1.46.jar!/:5.1.46]
   at com.mysql.jdbc.ConnectionImpl.coreConnect(ConnectionImpl.java:2188) ~[mysql-connector-java-5.1.46.jar!/:5.1.46]
   at com.mysql.jdbc.ConnectionImpl.connectOneTryOnly(ConnectionImpl.java:2221) ~[mysql-connector-java-5.1.46.jar!/:5.1.46]
   at com.mysql.jdbc.ConnectionImpl.createNewIO(ConnectionImpl.java:2016) ~[mysql-connector-java-5.1.46.jar!/:5.1.46]
   at com.mysql.jdbc.ConnectionImpl.<init>(ConnectionImpl.java:776) ~[mysql-connector-java-5.1.46.jar!/:5.1.46]
   at com.mysql.jdbc.JDBC4Connection.<init>(JDBC4Connection.java:47) ~[mysql-connector-java-5.1.46.jar!/:5.1.46]
   at sun.reflect.NativeConstructorAccessorImpl.newInstance0(Native Method) ~[na:1.8.0_242]
   at sun.reflect.NativeConstructorAccessorImpl.newInstance(NativeConstructorAccessorImpl.java:62) ~[na:1.8.0_242]
   at sun.reflect.DelegatingConstructorAccessorImpl.newInstance(DelegatingConstructorAccessorImpl.java:45) ~[na:1.8.0_242]
   at java.lang.reflect.Constructor.newInstance(Constructor.java:423) ~[na:1.8.0_242]
   at com.mysql.jdbc.Util.handleNewInstance(Util.java:425) ~[mysql-connector-java-5.1.46.jar!/:5.1.46]
   at com.mysql.jdbc.ConnectionImpl.getInstance(ConnectionImpl.java:386) ~[mysql-connector-java-5.1.46.jar!/:5.1.46]
   at com.mysql.jdbc.NonRegisteringDriver.connect(NonRegisteringDriver.java:330) ~[mysql-connector-java-5.1.46.jar!/:5.1.46]
    at com.zaxxer.hikari.util.DriverDataSource.getConnection(DriverDataSource.java:138) ~[HikariCP-3.4.1.jar!/:na]
    at com.zaxxer.hikari.pool.PoolBase.newConnection(PoolBase.java:353) ~[HikariCP-3.4.1.jar!/:na]
    at com.zaxxer.hikari.pool.PoolBase.newPoolEntry(PoolBase.java:201) ~[HikariCP-3.4.1.jar!/:na]
    at com.zaxxer.hikari.pool.HikariPool.createPoolEntry(HikariPool.java:473) [HikariCP-3.4.1.jar!/:na]
    at com.zaxxer.hikari.pool.HikariPool.checkFailFast(HikariPool.java:562) [HikariCP-3.4.1.jar!/:na]
    at com.zaxxer.hikari.pool.HikariPool.<init>(HikariPool.java:115) [HikariCP-3.4.1.jar!/:na]
    at com.zaxxer.hikari.HikariDataSource.getConnection(HikariDataSource.java:112) 

我的 Dockerfile,我使用 Maven 安装创建了一个 .jar 文件:

FROM openjdk:8
EXPOSE 8083
ADD target/ProjectCrud.jar ProjectCrud.jar
ENTRYPOINT ["java", "-jar", "ProjectCrud.jar"]

docker-compose.yml:

version: '3'
    services:
        docker-mysql:
            restart: always
            container_name: docker-mysql
            image: mysql
            environment:
                MYSQL_DATABASE: pfa
                MYSQL_ROOT_PASSWORD: aze123qsd
                MYSQL_USER: root
                MYSQL_ROOT_HOST: '%'
            volumes:
                - ./sql:/docker-entrypoint-initdb.d
            networks:
                - spring-db

            ports:
                - "3306:3306"
            healthcheck:
                test: "/usr/bin/mysql --user=root --password=root--execute \"SHOW DATABASES;\""
            interval: 2s
            timeout: 20s
            retries: 10


        sign-up-app:
            build: ./
            expose:
                - "10222"
            ports:
                - 10222:10222
            environment:
                WAIT_HOSTS: mysql:3306
            depends_on:
                - docker-mysql
            networks:
                - spring-db
  networks:
    spring-db:

我的 application.properties:

    spring.datasource.username=root
    spring.datasource.password=aze123qsd
    spring.datasource.driver-class-name=com.mysql.jdbc.Driver
    spring.jpa.hibernate.ddl-auto=update
    spring.datasource.url=jdbc:mysql://docker-mysql:3306/pfa? 
    useUnicode=true&useJDBCCompliantTimezoneShift=true&useLegacyDatetimeCode=false&serverTimezone=UTC
    server.port=8089

我尝试使用 docker 默认 ip 在我的本地机器上运行我的 spring boot 应用程序,同时在这个 docker-compose.yml 文件中只运行 MySql 容器,它运行良好。但是当我尝试 docker 撰写文件时。我得到这个错误

【问题讨论】:

    标签: java mysql spring docker docker-compose


    【解决方案1】:

    这可能是因为 contextLoads() 的测试失败,Jar 的构建失败。我遇到了类似的问题。可以参考this

    这可能是因为测试在您的本地运行,它无法解析 docker-mysql 作为参考。它只能被同一网络中的容器引用。您可以修复此覆盖测试属性并让它们使用您本地主机的数据库或内存数据库。

    尝试在测试类上使用这个:@SpringBootTest(properties = {"spring.datasource.url=jdbc:mysql://localhost:3306/dbname"})

    【讨论】:

    • 或者作为一种解决方法,您可以完全忽略测试,将其标记为已忽略或全部注释掉。
    • 但我使用 MySql 作为 docker 的容器,我认为这会报错。
    • 这就是重点。就连我也是。当您使用 mvn clean install 构建 jar 时,测试将在您的本地运行。它无法指向您在 docker 容器上运行的 MySQL。因此,覆盖它以指向您的本地数据库。
    • 如果您没有安装本地数据库或不想运行该测试,您可以随时禁用该测试,但不建议这样做。
    • 是的,现在我可以正确地创建我的 .jar 文件,但在 docker 上我仍然遇到同样的错误。
    【解决方案2】:

    我遇到了类似的问题,可能在主应用程序启动之前没有创建数据库。就我而言,我删除了数据库的卷:

    然后运行 ​​docker-compose up - 主应用程序应该以代码 -1 退出,之后 mysql 数据库应该开始工作,

    等待数据库创建完成,

    停止应用,按 ctrl+c,最后再次运行 docker-compose up。

    之后一切都应该工作了

    【讨论】:

    • 我唯一想到的就是从作曲家中删除所有networks。然后它应该使用默认网络,但这是 .好主意可能不是清除所有图像等,然后强制重新构建它。我用docker system prune -a
    猜你喜欢
    • 2020-07-12
    • 2020-08-05
    • 2021-06-14
    • 2019-07-07
    • 2020-04-23
    • 2023-02-23
    • 2021-08-02
    • 2019-06-06
    相关资源
    最近更新 更多