Никакая активная транзакция после перехода с JDK 8 на 11, Spring 4.3.30 на 5.1.20 и Hibernate 5.2.13 на 5.4.33JAVA

Программисты JAVA общаются здесь
Ответить
Anonymous
 Никакая активная транзакция после перехода с JDK 8 на 11, Spring 4.3.30 на 5.1.20 и Hibernate 5.2.13 на 5.4.33

Сообщение Anonymous »

Я недавно перенес веб-приложение на основе Java и столкнулся с проблемами транзакций после следующих обновлений:
JDK: с 8 на 11
Spring: с 4.3. 30.RELEASE до 5.1.20.RELEASE
Гибернация: с 5.2.13.Final до 5.4.33.Final
После миграции некоторые методы службы, помеченные @Transactional, больше не запускают транзакции, что приводит к следующей ошибке:

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

javax.persistence.TransactionRequiredException: no transaction is in progress
Here’s an example service method that fails to initiate a transaction:
Java

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

@Service
public class TicketServiceImpl {

@Autowired
private TicketUpdatePersistence ticketPersistence;

@Transactional
public void createTicketUpdate(TicketUpdate update) {
Ticket ticket = ticketPersistence.findById(update.getTicket().getId())
.orElseThrow(() -> new EntityNotFoundException("Ticket not found"));

System.out.println("Transaction active: " + TransactionSynchronizationManager.isActualTransactionActive());

Ticket lockedTicket = ticketPersistence.findOneForUpdate(ticket.getId())
.orElseThrow(() -> new BadRequestException("No ticket found for update"));
}
}
Проблема: TransactionSynchronizationManager.isActualTransactionActive() возвращает false, и при попытке обновить билет в базе данных выдается исключение TransactionRequiredException.
Что я пробовал:
Конфигурация транзакции:
Я проверил, что менеджер транзакций настроен правильно:
xml Публичный метод: метод является общедоступным, и к нему правильно применяется @Transactional.
Нет самовызова: я убедился, что есть нет самовызова метода @Transactional, поскольку он вызывается извне.
Механизм блокировки: уровень сохраняемости использует пессимистическую блокировку в методе findOneForUpdate:
Ява

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

@Lock(LockModeType.PESSIMISTIC_WRITE)
@Query("SELECT t FROM Ticket t WHERE t.id = :id")
Ticket findOneForUpdate(@Param("id") String ticketId);
мой файл конфигурации db.xml

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









































com.quicktech.quicktech.common.model













моя общая XML-конфигурация Spring Мои вопросы:
Что может быть причиной неактивации транзакций после перехода с Spring 4.3 на 5.1 и Hibernate 5.2 на 5.4?
Есть ли какие-либо известные изменения в Spring 5 или Hibernate 5.4, которые могут повлиять на поведение управления транзакциями?
Может ли эта проблема быть связана с переходом с JDK 8 на JDK 11, и если да, то как ее решить?
Буду признателен любые предложения или действия по устранению неполадок для решения этой проблемы. Заранее спасибо!
Дополнительная информация:
База данных: PostgreSQL 12
Весенняя версия: 5.1.20.RELEASE
Hibernate Версия: 5.4.33.Final
Версия JDK: 11.0.24
Сервер приложений: Apache Tomcat 9.0.55

Подробнее здесь: https://stackoverflow.com/questions/790 ... -to-5-1-20
Ответить

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

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

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

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

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