Логотип YeaHub

База вопросов

Собеседования

Тренажёр

База ресурсов

Обучение

Навыки

Задачи

Войти

Выбери, каким будет IT завтра — вместе c нами!

YeaHub — это полностью открытый проект, призванный объединить и улучшить IT-сферу. Наш исходный код доступен для просмотра на GitHub. Дизайн проекта также открыт для ознакомления в Figma.

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Golang: pattern, outbox, transaction, kafka, consistency

Что такое transactional outbox и зачем он нужен?

Сообщения между сервисами

Короткий ответ

Transactional outbox — это способ гарантированной доставки сообщений между сервисами. Он сохраняет сообщение в БД в рамках бизнес-транзакции, а затем отправляет его асинхронно.

Длинный ответ

Проблема: бизнес-операция (например, создание заказа) и отправка события в брокер (Kafka, RabbitMQ) не атомарны. Возможен сбой между db.Commit() и kafka.Send().

Transactional outbox решает эту проблему:

  1. В рамках транзакции сохраняются и бизнес-данные, и сообщение в таблицу outbox.

  2. Отдельный воркер читает outbox и отправляет сообщение в брокер.

  3. После успешной отправки сообщение помечается как обработанное или удаляется.

Этот паттерн повышает надёжность и устраняет рассинхрон между базой и брокером.

  • Аватар

    Golang Guru

    Maxim Lukyanov

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.

Уровень

  • Рейтинг:

    5

  • Сложность:

    7

Навыки

  • Golang

    Golang

  • Postgres

    Postgres

  • Kafka

    Kafka

Ключевые слова

#pattern

#outbox

#transaction

#kafka

#consistency

Подпишись на Golang Developer в телеграм

  • Аватар

    Golang Guru

    Maxim Lukyanov

    Guru – это эксперты YeaHub, которые помогают развивать комьюнити.