Ага
А че?
Подскажи, пожалуйста, как правильно нужно сделать. Когда есть куча сигналов, их количество только растет, может параллельно придти запрос на эту же запись Она щас лочиться через SEELCT FOR NO KEY UPDATE и ожидание, пока эти сигналы прогонятся, неприятное
Ну у меня сигналы пока не руинят, внутри них можно же проверки делать - что апдейтиться, что создается, какие данные были до, например. Можно fsm попробовать.
Ну просто проблем не было, когда было n количество сигналов, после того как ещё парочка добавилась, то параллельные запросы могли ловить дедлок
Значит надо старые поправить или новые, чтобы не было. Я ж могу только абстрактно предполагать что у тебя случилось. Рассмотреть все возможные сценарии и закодить там где есть пропуски.
А ну значит у тебя в зависимости от каких то полей сигналы делали разное.
Похоже на правду, там просто ещё не так просто с ним разобраться (По крайней мере мне) из-за того, что отношения там тоже запускают сигналы, как то так
А отношения как? Через апдейт? Тогда может и там апдейтитт только выбранные поля
Ща 5 сек, дойду до дома
А я щас в поезде из мск в питер гоню, вообще разорваться могу скоро )
Вообщем, если кто-то добавляет товар в заказ, то заказ мы точно должны обновить и прогнать сигналы и того и того (работаю в строй компании, так что там заказы замудренные ппц, много бизнес логики на все случаи жизни), а кто то может ещё и в этот момент обновить заказ и сигналы тоже обязаны от работать Сначала там вообще не было select for update, и так получалось, что кто то добавил товар, а кто то обновил заказ в один и тот же момент, и один из запросов переписывал изменения другого, я добавил select for update и все было супер до дедлока, потом я расставил, что я сказал уже и вроде бы дедлоки больше не падают
Т.е. заказ одновременно может обновлять несколько разных систем или пользователей? Жестко конечно. Но кстати эксплицитное управление блокировками как раз и повышает шансы взаимоблокировок. For update вррде самый жесткий так что может и поможет.
Он там обновляет несколько отношений
И все эти отношения ты тоже эксплицитно теперь обновляешь?
Расшифруй плз! Напрямую?
Обсуждают сегодня