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

Всем привет! Я могу через pg_try_advisory_lock сделать dictributed lock? У меня есть

куча инстансов одного сервиса и они иногда могут запустить бекграунд воркеры для обработки одних и тех же ресурсов.
Нужно получить блокировку на ресурс через другой сервис. Сейчас пробую PG

Т.е. кто успел тот и работает, остальные пробуют получить ресурс но получают false

PG для этого подходит? что-то локально не могу все это повторить...

2 ответов

36 просмотров

можно попробовать конструкцию select for update skip locked, если я правильно понял задачу

Что будете делать, если инстанс возьмёт блокировку, а потом умрёт? Если у вас стоит пуллер (pgbouncer к примеру), то блокировка будет держаться скорее всего после того, как умрёт инстанс, так как соединение вернётся в пул и сессия будет дальше жить, но на стороне pg_bouncer-а. Возможно получится что-то такое сделать, если использовать pg_try_advisory_xact_lock, так как в этом случае транзакция должна откатываться. Правда, если будут сетевые сбои (соединение между инстансом и pgbouncer-ом нет из-за умершего маршрутизатора) посередине, то могут быть тоже нюансы, так как tcp не разорвётся сразу. Можно правда рассмотреть keepalive соединенния, не знаю, можно ли их настроить на стороне драйвер/pg, чтобы решить данную проблему.... Но вообще я бы помотрел в сторону zookeeper, etcd.

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

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

Мужики и девушки, привет) в Вelphi xe7 в настройках во вкладке "Editor Options" далее " Color" есть список: "Elements", открыв который мы можем настраивать отображение разных...
Kraszx
14
Добрый вечер. Есть вопрос, а может и предложение. Был у меня диалог в другой группе о делфи и я задался вопросом: "А нельзя ли в делфи цвет //коментария и {комментария} сде...
Kraszx
24
Всем привет! Подскажи, пожалуйста, как передать в TComboBox сразу значение и id записи. На Delphi я делал так: ComboBox1.Items.AddObject('Какое-то значение', Pointer(id запис...
Евгений
13
А вот это что за конструкция? Вернее, она тут нафига?
Serjone
10
Мдя, прикол, боевая сборка запускается (именно под отладчиком) после F9 примерно полторы минуты (97 секунд если быть точным). Начал копать - проблема детектится сразу - зависа...
Александр (Rouse_) Багель
38
Мужики. привет) в Вelphi xe7 в настройках во вкладке "Editor Options" далее " Color" есть список: "Elements", открыв который мы можем настраивать отображение разных элементов...
Kraszx
2
Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
50
Товарищи, кто работа с iphelper? Или может я в самой логике ошибки фигачу, не пойму.... var ifTable : PMIB_IFTABLE; size, corSize: DWORD; Buffer ...
Warfarellen
4
я так понимаю, я так подозреваю, что создание такого плагина для человека, кто умеет писать плагины для делфи потребует минут 5-10 времени. но это мое подозрение. хотелось бы ...
Kraszx
7
Всем привет! Кто пользуется DevExpress, подскажите пожалуйста, реализован ли в TcxGrid в новых версиях поиск по датам как в Экселе (ну т.е. не просто список чекбоксов со значе...
A Z
4
Карта сайта