21.04.2019, 23:44 | #1 |
Участник
|
Не обновляется статус BatchJob после завершения
Коллеги, добрый день.
В АХ2009 последние несколько дней наблюдаю странную ситуацию - в пакетных заданиях статус Batch переходит в "Завершено", а статус "BatchJob" зависает на неопределнное время в "Выполнение". Особенности ситуации: 1. В БД при этом нет блокировок 2. Ситуация касается не отдельных пакетных заданий, а всех 3. Ситуация возникает время от времени - день работает нормально -> зависание -> далее снова какое-то время работает нормально и так далее. Закономерности четкой нет. 4. Если обновить статус пакетного задания точечно в "Отмена", а затем в "Ожидание", то он снова нормально стартует и продолжает нормально работать неопределенное время 5. Ситуация может разрешиться сама собой - т.е. пакеты снова массово переходят в статус "Ожидание" и далее по кругу. 6. На BatchJob в свойствах таблицы убрал кэширование Сталкивался ли кто-нибудь с подобным? Если да, то как решили данную ситуацию? На что следует обратить внимание при решении ситуации, "куда смотреть"? Спасибо.
__________________
С уважением, Александр. |
|
22.04.2019, 06:44 | #2 |
Участник
|
Предлагаю пересоздать индексы.
А дальше внимательно курить методы класса batchrun, переводящие статусы. |
|
22.04.2019, 06:51 | #3 |
Участник
|
Повспоминать, что могло в бд поменяться при смене сервера.
Версия винды. Какие то обновления sql? |
|
|
За это сообщение автора поблагодарили: samolalex (4). |
22.04.2019, 07:39 | #4 |
Участник
|
Статус завершается вроде бы отдельным обработчиком. Может у вас просто не хватает потоков(они все заняты чем-то).
Можно попробовать увеличить "Максимальное число потоков в пакетном задании" в конфигурации сервера |
|
|
За это сообщение автора поблагодарили: samolalex (4). |
22.04.2019, 09:51 | #5 |
Участник
|
Александр, стоит посмотреть нет ли ожидания работы SP_GETAPPLOCK (у нас, точнее теперь у вас, он логируется).
Там же где пакетные задачи есть запрос об ожиданиях разрешения на запуск. Большие ли там ожидания для процесса, в имени которого есть FinishedJobs? |
|
|
За это сообщение автора поблагодарили: samolalex (4). |
22.04.2019, 10:46 | #6 |
Участник
|
Алексей, спасибо. Проверил по логу интервалы времени возникновения зависаний.
Ожиданий работы SP_GETAPPLOCK в это время нет.
__________________
С уважением, Александр. |
|
22.04.2019, 21:15 | #7 |
Участник
|
Тогда, возможно, стоит помониторить как работает метод класса
X++: BatchRun::serverProcessFinishedJobs Цитата:
if(!shouldProcess)
return; Возможно, стоит в лог писать данные о значении thisDate и batchGlobal.LastProcFinishedJobs. Поятно, что логирование работы с bacthGlobal имеет смысл делать, если будет понятно, что дело в срабатывании if(!shouldProcess). PS: в любом случае, метод вызывается часто, поэтому записей в логе будет много, нужно будет чистить его время от времени. Последний раз редактировалось Raven Melancholic; 22.04.2019 в 21:19. Причина: Орфографические ошибки |
|
|
За это сообщение автора поблагодарили: Logger (3). |
23.04.2019, 08:23 | #8 |
Участник
|
Может у вас появились пакетные задания с BatchConstraint? Попробуйте удалить записи из этой таблицы в момент закипания статуса пакетов.
|
|
04.06.2019, 14:49 | #9 |
Участник
|
Добрый день.
Была аналогичная проблема. Поскольку BatchGlobal обновляется в отдельной транзакции - он всегда содержит данные, "якобы" метод уже обновил всю необходимую информацию. Хотя на самом деле выполнение кода "оборвалось" на какой-либо вставке записей в таблицы истории. |
|
|
За это сообщение автора поблагодарили: gl00mie (3). |
04.06.2019, 16:43 | #10 |
Участник
|
У меня бывало, что:
1) Если при работе пакетного задания запустить пересборку цила, то пакетник зависал (навсегда). Связано это с тем что сервисы отключаются при этом, и уже нормально не подхватывается пакет после такого. Спасало только полная очистка всех строк пакетника (таблица вроде Batch), либо обновление статуса вручную (джобом). 2) Бывает что когда одновременно много потоков (один или несколько пакетников работает), и в каждом потоке есть большой инфолог (который пакуется в batch поле таблицы), то возникали блокировки на уровне SQL, так как по факту могут быть большие объемы данных, и SQL физически не успевал все делать. Но этот способ легко ловить обычным sp_whoisactive на sql. P.s. Возможно у вас что-то иное, делюсь своими кейсами. |
|
|
За это сообщение автора поблагодарили: Logger (3). |