170 похожих чатов

18 ответов

16 просмотров

Ага

kuzmich- Автор вопроса
Roman
Ага

Слушай, у тебя ведь проект сложноватый я так полагаю?

А че?

kuzmich- Автор вопроса
Roman
А че?

Подскажи, пожалуйста, как правильно нужно сделать. Когда есть куча сигналов, их количество только растет, может параллельно придти запрос на эту же запись Она щас лочиться через SEELCT FOR NO KEY UPDATE и ожидание, пока эти сигналы прогонятся, неприятное

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

kuzmich- Автор вопроса
Roman
Ну у меня сигналы пока не руинят, внутри них можно...

Ну просто проблем не было, когда было n количество сигналов, после того как ещё парочка добавилась, то параллельные запросы могли ловить дедлок

kuzmich
Ну просто проблем не было, когда было n количество...

Значит надо старые поправить или новые, чтобы не было. Я ж могу только абстрактно предполагать что у тебя случилось. Рассмотреть все возможные сценарии и закодить там где есть пропуски.

А ну значит у тебя в зависимости от каких то полей сигналы делали разное.

kuzmich- Автор вопроса
Roman
А ну значит у тебя в зависимости от каких то полей...

Похоже на правду, там просто ещё не так просто с ним разобраться (По крайней мере мне) из-за того, что отношения там тоже запускают сигналы, как то так

kuzmich
Похоже на правду, там просто ещё не так просто с н...

А отношения как? Через апдейт? Тогда может и там апдейтитт только выбранные поля

kuzmich- Автор вопроса
kuzmich
Ща 5 сек, дойду до дома

А я щас в поезде из мск в питер гоню, вообще разорваться могу скоро )

kuzmich- Автор вопроса
Roman
А я щас в поезде из мск в питер гоню, вообще разор...

Вообщем, если кто-то добавляет товар в заказ, то заказ мы точно должны обновить и прогнать сигналы и того и того (работаю в строй компании, так что там заказы замудренные ппц, много бизнес логики на все случаи жизни), а кто то может ещё и в этот момент обновить заказ и сигналы тоже обязаны от работать Сначала там вообще не было select for update, и так получалось, что кто то добавил товар, а кто то обновил заказ в один и тот же момент, и один из запросов переписывал изменения другого, я добавил select for update и все было супер до дедлока, потом я расставил, что я сказал уже и вроде бы дедлоки больше не падают

kuzmich
Вообщем, если кто-то добавляет товар в заказ, то з...

Т.е. заказ одновременно может обновлять несколько разных систем или пользователей? Жестко конечно. Но кстати эксплицитное управление блокировками как раз и повышает шансы взаимоблокировок. For update вррде самый жесткий так что может и поможет.

kuzmich- Автор вопроса
Roman
Т.е. заказ одновременно может обновлять несколько ...

Он там обновляет несколько отношений

kuzmich
Он там обновляет несколько отношений

И все эти отношения ты тоже эксплицитно теперь обновляешь?

kuzmich- Автор вопроса

Похожие вопросы

Обсуждают сегодня

а через ESC-код ?
Alexey Kulakov
29
30500 за редактор? )
Владимир
47
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
program test; {$mode delphi} procedure proc(v: int32); overload; begin end; procedure proc(v: int64); overload; begin end; var x: uint64; begin proc(x); end. Уж не знаю...
notme
6
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
вы делали что-то подобное и как? может есть либы готовые? увидел картинку нокода, где всё линиями соединено и стало интересно попробовать то же в ddl на lua сделать. решил с ч...
Victor
8
Ребят в СИ можно реализовать ООП?
Николай
33
Подскажите пожалуйста, как в CustomDrawCell(Sender: TcxCustomGridTableView; ACanvas: TcxCanvas; AViewInfo: TcxGridTableDataCellViewInfo; var ADone: Boolean); получить наз...
A Z
7
Карта сайта