MySQL: EOFException: не удается прочитать ответ с сервера. Ожидается чтение 4 байтов, чтение 0 байтов, прежде чем соединение было неожиданно потеряно - PullRequest
0 голосов
/ 15 апреля 2019

У меня есть приложение Spring с кварцевым планировщиком для пакетной обработки. Это работало нормально с прошлых 4 лет. Существует партия, которая запускается каждые 1 минуту. Но в последние несколько дней, когда пакет пытается получить некоторые данные, мы получаем org.springframework.transaction.CannotCreateTransactionException: Could not open Hibernate Session for transaction; nested exception is org.hibernate.exception.JDBCConnectionException: Could not open connection

Этот пакет выполняется в течение дня, но иногда дает это исключение, а все другие пакеты не могут подключиться к MySQL. Итак, мы перезапускаем приложение, и оно работает нормально.

Конфигурация источника данных

<bean id="dataSource" class="org.springframework.jdbc.datasource.DriverManagerDataSource">
        <property name="url">
            <value>${DATABASE_URL}</value>
        </property>
        <property name="driverClassName">
            <value>com.mysql.jdbc.Driver</value>
        </property>
        <property name="username">
            <value>${DATABASE_USER}</value>
        </property>
        <property name="password">
            <value>${DATABASE_PASSWORD}</value>
        </property>
</bean>

Конфигурация пула соединений фабричной сессии

<bean id="sessionFactory"
        class="org.springframework.orm.hibernate4.LocalSessionFactoryBean">
<property name="dataSource" ref="dataSource" />
<property name="hibernateProperties">
<props>
<prop key="hibernate.dialect">org.hibernate.dialect.MySQLDialect</prop>
<prop key="hibernate.show_sql">false</prop>
<prop key="hibernate.enable_lazy_load_no_trans">true</prop>
<!-- Configurations specific to c3p0 connection pooling -->

<prop key="hibernate.c3p0.acquire_increment">5</prop>
<prop key="hibernate.c3p0.idle_test_period">1800</prop>
<prop key="hibernate.c3p0.max_size">600</prop>
<prop key="hibernate.c3p0.max_statements">50</prop>
<prop key="hibernate.c3p0.min_size">5</prop>
<prop key="hibernate.c3p0.timeout">1800</prop>
</props>
</property>
<property name="annotatedClasses">
<list> .... </list>
</property>
</bean>

Ответы [ 2 ]

1 голос
/ 16 апреля 2019

Возможно, это проблема с mysql, на котором работает ваш db-сервер.

измените конфигурацию mysql на вашем db-сервере

добавьте bind-адрес в mysql.cnf под [mysqld] section

bind-address=your_spring_application_ip

также изменяет доступ к хосту для пользователя mysql.выполните следующий запрос в mysql

update mysql.user set host='%' where user='your_username';
flush privileges;

, затем перезапустите службу mysql

sudo systemctl restart mysql
0 голосов
/ 15 апреля 2019

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

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