Хобрук: Ваш путь к мастерству в программировании

Как разрешить распределенную транзакцию java.sql.SQLException, ожидающую блокировки

Мы используем комбинацию Oracle 11G и JDK1.8. В нашем приложении мы используем XAConnection, XAResource для транзакции БД. т. е. распределенные транзакции.

В некоторых случаях нам нужно убить наш процесс Java, чтобы остановить приложение. После уничтожения, если мы перезапустим наше приложение, мы получим следующее исключение при выполнении транзакции БД.

java.sql.SQLException: ORA-02049: timeout: distributed transaction
waiting for lock

После этого в течение нескольких часов мы не можем использовать наше приложение, пока не будет снята блокировка.

Может ли кто-нибудь дать мне какое-нибудь решение, чтобы мы могли продолжить работу, а не ждать снятия блокировки.

Я пробовал следующий вариант:

а) Получен SID и завершение сеанса с помощью команды alter. После этого блокировка таблицы также не снимается.

Я имею дело с очень небольшим объемом данных.


  • Как ты убил сессию - опцией immediate? Убить процесс Java кажется жестким подходом. Не можете ли вы добавить механизм для запуска чистого выхода; или приложение находится в состоянии, когда оно все равно не отвечает? 25.08.2016
  • Есть ли в dba_2pc_pending строка для ожидающей распределенной транзакции, которую можно зафиксировать или откатить? 25.08.2016
  • @justin Cave Нет доступных строк в dba_2pc_pending 26.08.2016

Ответы:


1

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

Соединения с Oracle остаются открытыми до тех пор, пока вы не завершите локальный сеанс или пока количество ссылок на базу данных для вашего сеанса не превысит значение OPEN_LINKS. Чтобы уменьшить нагрузку на сеть, связанную с поддержанием связи с базой данных открытой, используйте это предложение для явного закрытия ссылки, если вы не планируете использовать ее снова в своем сеансе.

Я считаю, что при закрытии ваших соединений и сеансов после выполнения DDL эта проблема не должна возникать.

Другая возможность дана на этот вопрос< /а>:

Одним из возможных способов может быть увеличение параметра INIT.ORA для Distributed_lock_timeout до большего значения. Это даст вам больше времени для наблюдения за таблицей v$lock, так как блокировки будут длиться дольше. Чтобы добиться автоматизации этого, вы можете: запускать задание SQL каждые 5-10 секунд, которое записывает значения v$lock или запрос, который Сандос дал выше, в таблицу, а затем анализируете его, чтобы увидеть, какой сеанс вызвал блокировку. . - Запустите STATSPACK или отчет AWR. Сеансы, которые были заблокированы, должны отображаться с большим истекшим временем и, следовательно, могут быть идентифицированы. В v$session есть еще 3 столбца blocking_instance, blocking_session, blocking_session_status, которые можно добавить к приведенному выше запросу, чтобы получить представление о том, что блокируется.

Надеюсь, я помог тебе, мой друг.

23.02.2018
Новые материалы

Основы принципов S.O.L.I.D, Javascript, Git и NoSQL
каковы принципы S.O.L.I.D? Принципы SOLID призваны помочь разработчикам создавать надежные, удобные в сопровождении приложения. мы видим пять ключевых принципов. Принципы SOLID были разработаны..

Как настроить Selenium в проекте Angular
Угловой | Селен Как настроить Selenium в проекте Angular Держите свое приложение Angular и тесты Selenium в одной рабочей области и запускайте их с помощью Mocha. В этой статье мы..

Аргументы прогрессивного улучшения почти всегда упускают суть
В наши дни в кругах веб-разработчиков много болтают о Progressive Enhancement — PE, но на самом деле почти все аргументы с обеих сторон упускают самую фундаментальную причину, по которой PE..

Введение в Джанго Фреймворк
Схема «работать умно, а не усердно» В этой и последующих статьях я познакомлю вас с тем, что такое фреймворк Django и как создать свое первое приложение с помощью простых и понятных шагов, а..

Настольный ПК как «одно кольцо, чтобы править всеми» домашних компьютеров
Вид после 9 месяцев использования С настольных компьютеров все началось, но в какой-то момент они стали «серверами», и мы все перешли на ноутбуки. В прошлом году я столкнулся с идеей настольных..

Расширенные методы безопасности для VueJS: реализация аутентификации без пароля
Руководство, которое поможет вам создавать безопасные приложения в долгосрочной перспективе Безопасность приложений часто упускается из виду в процессе разработки, потому что основная..

стройный-i18следующий
Представляем стройную оболочку для i18next. Эта библиотека, основанная на i18next, заключает экземпляр i18next в хранилище svelte и отслеживает события i18next, такие как languageChanged,..