Код: Выделить всё
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');
Первая вставка завершилась успешно.
2-й запрос мгновенно выдает исключение - java.sql.SQLIntegrityConstraintViolationException: Повторяющаяся запись....
После этого все последующие вставки перешли в состояние ожидания на все 50 секунд (
Код: Выделить всё
innodb_lock_wait_timeoutMysql Медленные журналы:
Код: Выделить всё
> 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');
В конце концов, все 5 соединений в пуле исчерпаны, и приложение начало выдавать:
Ошибка:
java.sql.SQLTransientConnectionException: HikariPool-1 — соединение недоступно...

Фрагмент кода
Код: Выделить всё
@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;
}
}
Мы восстановились после перезапуска приложения, чтобы освободить исчерпанный пул.
версия :
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
< /code>
q. Утечка подключения: почему Hikaricp не выпускает подключения после того, как MySQL не превышает запрос (как видно в медленных журналах сразу после 50 -х годов), и как я могу автоматически привязать такие соединения?
Подробнее здесь: https://stackoverflow.com/questions/797 ... rt-queries
Мобильная версия