Почему лучше не публиковать в брокер сообщений внутри Postgres транзакции? Нашел

паттерны для того, чтобы делать это после транзакции:
https://microservices.io/patterns/data/transactional-outbox.html
https://microservices.io/patterns/data/transaction-log-tailing.html

Также не понятно зачем в этих паттернах привязываться к таблицам из Postgres, чтобы понять, что транзакция выполнилась успешно. Можно же это публиковать после успешного commit транзакции. Также вероятно надо добавить ретраи на все это дело.

4 ответов

18 просмотров

Транзакции блокируют другие операции с таблицей, поэтому чем раньше ее закроешь, тем лучше

Shaplin-Шаплин Автор вопроса
√Григорий
Транзакции блокируют другие операции с таблицей, п...

Вот да! Думал, что есть какие-то другие еще причины)

Shaplin Шаплин
Вот да! Думал, что есть какие-то другие еще причин...

Если ты публикуешь до завершения транзакции, то в случае роллбека тебе и с публикацией что-то делать придется

Shaplin Шаплин
Вот да! Думал, что есть какие-то другие еще причин...

Если ты закоммитил транзакцию в БД и потом не смог отправить сообщение в очередь - ты уже не сможешь откатить транзакцию в бд. Т.е. система будет уже в неконсистентном состоянии. В книге Microservices Patterns про это целая глава есть, там более подробно написано.

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

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

Это может быть все-таки не флудвейт? у меня ботфазер принимает изменения и отображает даже что они изменились, на видео видно что он прислал якобы уже измененное описание, н...
OVERLINK
13
всем привет помогите пожалуйста используя CDN (GCP) у игроков из вьетнама загружается конфиг (размер 999 bytes) загружается 5 и более минут н а других CDN сервисах такой пробл...
Andrew Krw.
1
Добрый день. Мне посоветовали обратиться к вам в чат за помощью. Ситуация описана на скрине. Как мне сказали, мне на бота навесили флудвейт. Есть ли возможность снять его ра...
OVERLINK
7
Просто по очереди выпиливаешь на ручной маппинг? По методу за раз
Andrii Kurdiumov
7
Приветствую. А не подскажете какие ограничения есть на использования api метода setMyName ? Несколько раз сменил имя бота и получил бан на 2 месяца на смену имени.
Slick Slack
8
И? Все равно глазами проверять надо каждое поле
Andrii Kurdiumov
4
Ну есть у нас десяток компаний которым надо. Остальным то зачем?
Andrii Kurdiumov
4
Всем привет! Взялся портировать модули на 18 версию, лезет _logger.log(log_level, 'no translation language detected, skipping translation %s', frame, stack_info=True) А чт...
Max Lit
3
Привет, коллеги! Возникла задача ограничить максимальный размер вложений для определённых расширений, например, чтобы для изображений лимит был 10 МБ, а для видео — 100 МБ. Ог...
Andro
1
Доброе утро, а кто то делал Google аналитику через php ? curl_setopt($ch, CURLOPT_NOSIGNAL, true); Это должно быть async без ожидания ответа. Вообще php нормально с таким с...
Max Dubovsky
9
Карта сайта