Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Задачи

Войти

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

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

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Golang: outbox, transactional messaging, kafka, consistency

Как устроен Outbox-паттерн и зачем он нужен?

Проверяет навыки работы с БД и очередями.

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

Outbox-паттерн сохраняет сообщение в таблицу вместе с изменением состояния, а потом отдельный процесс (consumer) читает и отправляет их в Kafka. Это обеспечивает атомарность между БД и очередью.

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

Outbox нужен для решения проблемы несогласованности между базой и очередью сообщений (например, Kafka). Проблема: если сначала обновить БД, а потом отправить сообщение — можно потерять сообщение при падении.

Суть Outbox-паттерна:

  1. В одной транзакции:

  • Изменяется бизнес-сущность.

  • Вставляется запись в таблицу outbox.

  1. Отдельный фоновый процесс:

  • Читает сообщения из outbox.

  • Отправляет в Kafka.

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

Преимущества:

  • Сообщение не теряется при сбоях.

  • Позволяет восстановить процесс с любого момента.

  • Поддерживает idempotency и retries.

  • Аватар

    Golang Guru

    Maxim Lukyanov

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

Уровень

  • Рейтинг:

    5

  • Сложность:

    7

Навыки

  • Golang

    Golang

  • Postgres

    Postgres

  • Kafka

    Kafka

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

#outbox

#transactional messaging

#kafka

#consistency

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

  • Аватар

    Golang Guru

    Maxim Lukyanov

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