|
02.04.2011, 23:45 | #1 |
Боец
|
AX2009: Ошибка оптимистической модели обновления
AX2009 SP1 RU6, SQL2008 R2. Один физический сервер, 15 Gb RAM
Ну вот, мы уже съели последний зуб, но на протяжении нескольких месяцев, но так и не можем решить эту проблему. И рыть больше некуда. Караул! В системе возникают конфликты обновления вида: Цитата:
Object Server 01: Optimistic Concurrency: Обновить конфликт, выявленный при выполнении следующего (с параметрами): UPDATE SOBJECTBALANCE SET BALANCEDAYS=?,CALCDATE=?,RECVERSION=?,MODIFIEDDATETIME=?,MODIFIEDBY=? WHERE (((DATAAREAID=?) AND (PIN=?)) AND (RECVERSION=?)) ; -378 ; 2011-3 ; 4620762011-03-2 ; 'malki ; '5' ; '11358 ; 429295
Итак: AOS и SQL на одной физическом сервере. Физически перегружаем сервер, пускаем пользователей. Несколько часов (а иногда день, два, три, четыре) все идет хорошо. Журнал ошибок Windows чистенький. Затем изредка проскакивают сообщения (информационные) вида выше. Затем их становится больше. При этом, они всё ещё информационные, и на работе пользователей не отражаются (т.е. у пользователя не выскакивает инфолог с соотв. ошибкой). Но ещё позже таких ошибок становится просто шквал и тут уж среди этого шквала проявляются уже не информационные ошибки, а настоящие, вида: Цитата:
Object Server 01: Dialog issued for client-less session 2: Cannot edit a record in Current client sessions (SysClientSessions).
An update conflict occurred due to another user process deleting the record or changing one or more fields in the record. Эти конфликты обновления возникают совершенно на любых таблицах аксапты, даже на тех, которые гарантированно использует только один пользователь (эксперементировали). Ну вот, вкрадце все. Что делать, как диагностировать? Пока я склонен грешить на железо. Планируем развернуть ещё один сервер и пробовать на другом железе, либо разнести АОС и SQL, либо ещё как-то... |
|
03.04.2011, 11:10 | #2 |
Участник
|
Если в итоге все доходит до того что глюк так легко воспроизводится, то может попробовать воспроизвести ошибку руками, посмотрев при этом кто когда редактировал табличку и какие сессии её на текущий момент держат ?
Судя по симптомам - у вас как-то перепутались соединения к БД. Ну то есть работало соединение к базе, в нем осталась незакрытая транзакция. Потом его хватает из пула соединений аоса другая сессия и пытается работать. А транзакция не закрыта, блокировки вешаются и вешаются, в том числе и на системные объекты и в итоге это все принимает совсем некрасивый вид. Но почему такое могло случиться - ума не приложу. Вы не кастомизировали работу с номерными сериями или другие места, где явно из кода используется отдельное соединение к базе ? |
|
03.04.2011, 12:53 | #3 |
Боец
|
Цитата:
С номерными сериями - нет, а вот прямой вызов SQL используется часто, правда, натравлен на другие БД. Т.е. БД аксапты напрямую не используется. Но на самом деле - хз, я не могу это на 100% исключить, т.к. систему насиловали долго и упорно. Как проверить эту версию? |
|
03.04.2011, 13:23 | #4 |
Участник
|
Цитата:
Прямо барабашка. А не может быть так что эта табличка уже открыта в обозревателе таблиц или в формочке из под вас же и в силу каких-то причин запись на форме сохраняется (бред конечно, но все же) Еще вариант - попробовать на этой табличке отключить оптимистическую конкуренцию. Если реально идет обновление кем-то, то скорее всего ваш джоб зависнет. Можно тогда посмотреть на ком и кто его держит. Еще вариант - может сиквел глючит в режиме Snapshot isolation - вы посмотрите там все порядке - места в темпах достаточно ? Не переполнились ? |
|
03.04.2011, 13:25 | #5 |
Участник
|
Кстати, недавно ковырялся по системным табличкам Аксапты и где-то попадался параметр, судя по названию, отвечающий за значение параметра OCC enabled по умолчанию. Может попробовать выключить. По крайней мере если заблокируется система, то увидите кто кого и когда и почему.
|
|
03.04.2011, 13:38 | #6 |
Боец
|
Цитата:
Цитата:
В общем глючит именно OCC, а вот почему - предстоит разобраться, что-то ей мешает. Места достаточно на всех дисках. Цитата:
Еще вариант - может сиквел глючит в режиме Snapshot isolation - вы посмотрите там все порядке - места в темпах достаточно ? Не переполнились ?
|
|
17.04.2013, 11:34 | #7 |
Модератор
|
С триггерами \ хранимыми процедурами с SET NOCOUNT ON баловались ? Если забыли где-то его вернуть в нормальное (для AX - OFF) состояние, в этой сессии при попытке UPDATE .. WHERE RECID = %X and RECVERSION = %Y ядро не увидит искомого '1 record affected' и решит что это конфликт OCC
__________________
-ТСЯ или -ТЬСЯ ? |
|
|
За это сообщение автора поблагодарили: Kabardian (5), dim-gin (1). |
21.01.2021, 15:14 | #8 |
Участник
|
Цитата:
Сообщение от Vadik
С триггерами \ хранимыми процедурами с SET NOCOUNT ON баловались ? Если забыли где-то его вернуть в нормальное (для AX - OFF) состояние, в этой сессии при попытке UPDATE .. WHERE RECID = %X and RECVERSION = %Y ядро не увидит искомого '1 record affected' и решит что это конфликт OCC
Вот тут https://www.sql.ru/forum/1332703/kak...zvolnoy-sessii утверждают, что при выходе из хранимки свойство должно восстанавливаться. Т.е. не должна хранимка смочь что либо испортить в сессии. P.S. Надо будет контрольный пример сбацать и проверить. |
|
21.01.2021, 22:03 | #9 |
Модератор
|
да, уверен
Цитата:
Вот тут
https://www.sql.ru/forum/1332703/kak...zvolnoy-sessii утверждают, что при выходе из хранимки свойство должно восстанавливаться. Т.е. не должна хранимка смочь что либо испортить в сессии. P.S. Надо будет контрольный пример сбацать и проверить X++: use tempdb go set nocount off go select count(*) from sys.objects go create procedure myProc as begin set nocount on; -- do something end go execute myProc go drop procedure myProc; go select count(*) from sys.objects go Цитата:
-----------
100 (1 row affected) ----------- 100 (1 row affected) Цитата:
If a SET statement runs in a stored procedure or trigger, the value of the SET option gets restored after the stored procedure or trigger returns control. Also, if you specify a SET statement in a dynamic SQL string that runs by using either sp_executesql or EXECUTE, the value of the SET option gets restored after control returns from the batch that you specified in the dynamic SQL string
на AX2012, при возможности проверю. T-SQL c NOCOUNT из X++ должен валиться P.S. подчеркнутое расходится с Цитата:
if you specify a SET statement in a dynamic SQL string that runs by using either sp_executesql or EXECUTE, the value of the SET option gets restored after control returns from the batch that you specified in the dynamic SQL string
__________________
-ТСЯ или -ТЬСЯ ? Последний раз редактировалось Vadik; 21.01.2021 в 23:22. |
|
|
За это сообщение автора поблагодарили: Logger (10). |
03.04.2011, 15:06 | #10 |
Moderator
|
Насколько я понимаю, оптимистическое обновление не имеет отношения к snapshot isolation. RCSI просто позволяет читать обновленные кем-то в незавершенных транзакциях записи. А оптимистическое обновление работает так: В оператор update/delete подставляется дополнительное условие RecVersion=429295 (в общем - с тем recversion, который был прочитан во время последнего чтения записи). Если после выполнения запроса из SQL Native Client приходит число обновленных записей, не равное единице, AOS понимает что запись вытащили из под носа и ругается.
Так что я бы в такой ситуации начал бы борьбу с обновления SQL Native Client на всех AOS-серверах. Для этого надо скачать последний Service Pack для SQL Server 2005, )(sp4) потом скачать последний cummulative update (cu3 на данный момент), а потом запустить установку всего этого хозяйства на ваших AOSах. Хочу специально заметить, что даже если вы везде используете только SQL 2008, то аксапта все равно работает со старым Native Client (2005), так что пытаться поставить native client от SQL 2008 на серверы с AOS - бесполезно. |
|
03.04.2011, 19:00 | #11 |
Участник
|
|
|
03.04.2011, 20:00 | #12 |
Участник
|
В микрософт запрос не отправляли?
|
|
03.04.2011, 21:23 | #13 |
Боец
|
Цитата:
Цитата:
Ещё нет. |
|
04.04.2011, 15:13 | #14 |
Участник
|
А у вас случаем не sql 2005?.. может ОСС на уровне бд поможет...
|
|
|
За это сообщение автора поблагодарили: DSPIC (0). |
17.09.2012, 10:30 | #15 |
Участник
|
Хотелось бы узнать - как решили проблему? У меня пока вылазит такое сообщение в логах АОС и иногда при пересчете склада на стороне клиента.
|
|
17.04.2013, 03:54 | #16 |
Участник
|
Включенный RCSI на БД должен помочь.
|
|
|
За это сообщение автора поблагодарили: Logger (1). |
17.04.2013, 11:29 | #17 |
Модератор
|
Ну, колеги, это уже шаманство какое-то.. Мы считали запись в буфер, держим ее там какое-то время, пытаемся ее обновить и выясняем в процессе что кто-то ее уже обновил до нас (значение RecVersion поменялось). Это чистой воды конфликт, вариантов его разрешения два, оба - на уровне приложения, а не БД:
- честно сказать "не могу" и сразу откатить транзакцию - откатить транзакцию, и попытаться перезапустить обработку в фоне (незаметно для пользователя), при повторных ошибках - см. п.1 RCSI здесь абсолютно не при чем
__________________
-ТСЯ или -ТЬСЯ ? |
|
17.04.2013, 11:55 | #18 |
Боец
|
1. Это было 2 года тому
2. Не помню точно чем это закончилось, но проблема как-то ушла сама, возможно, после профилактики работ с дисками или чем-то в этой области. Проблема была не в том что изменялся RecVersion. Я помню, что мы экспериментировали, создавая новую таблицу и запускали в цикле update. 2 из 50 проваливались. У меня было ощущение, что АОС "не успевал" следить за изменением RecVersion: 1) RecVersion1 -> Update1 -> RecVersion2 2) RecVersion1 -> Update2 -> RecVersion3 Т.е. перед 2-ым update АОС брал RecVersion1, который был ещё ДО 1-го апдейта. Это догадки, проверить это не удалось. |
|
29.11.2013, 15:19 | #19 |
Участник
|
Всем, привет!
Подскажите есть ли у кого-нибудь решение этой проблемы. Постоянно у всех пользователей сыпятся ошибки (см. вложение). Ругается на разные таблицы, в зависимости от того какой функционал зайдествован. Перезапуск АОС на какое-то время помогает. MDAX 2009 (RU7), SQL Server 2008 EE (Build 10.0.5835) Последний раз редактировалось Just_smile; 29.11.2013 в 15:22. |
|
30.11.2013, 08:57 | #20 |
Боец
|
В итоге мы отключили оптимистичечкую модель обновления, после чего все беды ушли. Разницы между оптимистической и пессимистической моделями на практике замечено не было, если не считать описанной выше проблемы.
Если в RU8 проблему не исправили, то рекомендую поступить так же. Последний раз редактировалось DSPIC; 30.11.2013 в 08:59. |
|
|
За это сообщение автора поблагодарили: Just_smile (1). |
Теги |
ax2009, ax2012, ax2012r2, occ, set nocount on, sysclientsessions, ошибка, хранимые процедуры |
|
Опции темы | Поиск в этой теме |
Опции просмотра | |
|