Утечка соединений hikaricp с запрашиваемыми вставками MySQLJAVA

Программисты JAVA общаются здесь
Ответить
Anonymous
 Утечка соединений hikaricp с запрашиваемыми вставками MySQL

Сообщение Anonymous »

Я сталкиваюсь с проблемой, в которой запросы вставки в таблице MySQL застряли в «ожидании блокировки», и даже после innodb_lock_wait_timeout (50S) соединения не выпускаются обратно в Hikaricp, в конечном итоге исчерпывая бассейн. (file_record_v2, уникальный файл_ид), с буфером 2-3 минуты между каждым запросом. < /p>

Код: Выделить всё

INSERT INTO file_record_v2
(iso_country_code,
created_at,
modified_at,
bucket,
file_id,
file_key,
file_name,
path,
status,
upload_date,
uploaded_by)
VALUES      ('IN',
'2025-10-01 17:22:39.867',
'2025-10-01 17:22:39.867',
'Fo/89NveRaWnfjgvfsmrIE5ca7kQ2LkqvV9AKTmn0Qw=',
'777a7379-6c96-35d1-b47e-17b1708258f5',
'abcdef',
'1759316708189.csv',
NULL,
'success',
'2025-10-01',
'admin@gmail.com');
< /code>
[b] Что происходит: < /strong> < /p>
Первая вставка преуспела.
2 -й запрос запросов мгновенно бросает исключение - java.sql.sqlintegrityConstraintviolationException: дублировать запись ...
После того, как все последующие вставки. Вошли в 50 -й секунды (все 50 -й секунды (все это касается 50 -й секунды.innodb_lock_wait_timeout
).
Mysql Медленные журналы: [/b]

Код: Выделить всё

> User@Host: admin[admin] @ [xx.xxx.xx.216] thread_id: 3225252 server_id: 2921685337
> Query_time: 50.939886 Lock_time: 50.939609 Rows_sent: 0 Rows_examined: 0 use
> shard0; SET timestamp=1759319339; insert into file_record_v2
> (iso_country_code, created_at, modified_at, bucket, file_id, file_key,
> file_name, path, status, upload_date, uploaded_by) values ('IN',
> '2025-10-01 17:18:59.548', '2025-10-01 17:18:59.548',
> 'Fo/89NveRaWnfjgvfsmrIE5ca7kQ2LkqvV9AKTmn0Qw=',
> '777a7379-6c96-35d1-b47e-17b1708258f5', 'abcdef', '1759316708189.csv',
> null, 'success', '2025-10-01', 'admin@gmail.com');
< /code>
Через 50 секунд MySQL Times Out запросов на ожидание, но Хикари не возвращает эти соединения в пул.
В конце концов, все 5 соединений в пуле становятся исчерпывающими, и приложение начало бросать: < /p>
[b] ошибка: < /strong>

javavexexexexexexexexexexexexexexexexexexexexexexexexexexexexexexexexexexexexexexexexexexexexexexexexexexexexexexexexexcre Hikaripool -1 - Соединение недоступно ... 
 
 кодовой Snipt [/b] 

[b] код [/b] 

[b] snippet [/b] 

[b] код.@Override
public FileUploadResponse storeFileMetadata(String bucketName, String fileKey, String fileName, String user, String countryCode) throws Exception {
String fileId = // create file id;
LocalDateTime localDateTime = getLocalDateTime();

try {
// Build entity
FileRecordEntity entity = FileRecordEntity.builder()
.fileId(fileId)
.fileName(fileName)
.uploadDate(getDate())
.bucket(bucketName)
.fileKey(fileKey)
.userId(user)
.status(FileStatus.SUCCESS.getValue())
.countryCode(countryCode)
.createdAt(localDateTime)
.modifiedAt(localDateTime)
.build();

fileRecordRepository.save(entity); // Only DB query which got latent

return new FileUploadResponse(fileId, null);

} catch (ConstraintViolationException | DataIntegrityViolationException e) {
log.error(e.getMessage(), e);
if (StringUtils.containsIgnoreCase(e.getCause().getCause().getMessage(), "Duplicate entry"))
throw new FileValidationException(String.format("Duplicate file: %s", fileName));
throw e;
}
}
recovery [/b]:
Мы восстановились после перезапуска приложения, чтобы освободить исчерпанный пул.
версия :

Код: Выделить всё

Spring Boot: 2.7.10
Spring Data JPA: 2.7.10
HikariCP: 4.0.3
Hibernate: 5.6.15.Final
Driver : com.mysql.cj.jdbc.Driver
В. Утечка соединения: почему HikariCP не освобождает соединения после того, как MySQL
истечет время выполнения запроса (как видно из медленных журналов сразу после 50 секунд), и как я могу заставить его автоматически обнаруживать и закрывать такие
соединения.


Подробнее здесь: https://stackoverflow.com/questions/797 ... rt-queries
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «JAVA»