Невозможно подключить SpringBoot к MySql с помощью Docker compose - PullRequest
0 голосов
/ 22 февраля 2020

Я создал файл 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, я создал файл .jar с помощью установки Maven:

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 по умолчанию, в то время как только * run8ig MySql контейнер в этом docker -компоненте Файл .yml, и он работал отлично. Но когда я пытаюсь docker составить файл. я получаю эту ошибку

Ответы [ 2 ]

0 голосов
/ 22 февраля 2020

У меня была похожая проблема, и, возможно, база данных не была создана до запуска основного приложения. В моем случае я удалил том базы данных:

, затем запустил docker -compose up - главное приложение должно выйти с кодом -1, после этого mysql база данных должна начать свою работу,

дождитесь создания базы данных,

остановите приложение, нажав ctrl + c, и, наконец, запустите docker - составьте заново.

После этого все должно работать

0 голосов
/ 22 февраля 2020

Вероятно, это связано с тем, что сборка Jar не удалась, так как проверка на contextLoads() не удалась. Я столкнулся с подобной проблемой. Вы можете сослаться на this

Вероятно, это связано с тем, что тесты выполняются на вашем локальном компьютере, и он не может разрешить docker-mysql в качестве ссылки. На него могут ссылаться только контейнеры в одной сети. Вы можете исправить это переопределение свойств теста и заставить их использовать базу данных вашего локального хоста или базу данных в памяти.

Попробуйте использовать это в классе теста: @SpringBootTest(properties = {"spring.datasource.url=jdbc:mysql://localhost:3306/dbname"})

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...