Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Задачи

Войти

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

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

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Golang: go, idempotency, consumer

Как реализовать идемпотентность при работе с Kafka?

Проверяет умение проектировать системы с гарантированной доставкой сообщений.

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

Идемпотентность достигается за счёт ключа сообщения (partition key) и хранения обработанных ID (в БД или Redis). Повторные события просто игнорируются.

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

Задача: если Kafka отправила одно и то же сообщение несколько раз (например, при failover), обработка должна выполняться только один раз.

Методы:

  1. Ключ события (message key):

    Kafka гарантирует порядок внутри одного partition по ключу.

  2. Хранение ID обработанных сообщений:

    • в Redis (ключ — ID, TTL для очистки);

    • в Postgres (таблица processed_messages).

  3. Upsert: вставка с ON CONFLICT DO NOTHING.

Вывод: идемпотентность — обязательна для корректной работы систем с брокерами.

  • Аватар

    Golang Guru

    Maxim Lukyanov

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

Уровень

  • Рейтинг:

    4

  • Сложность:

    8

Навыки

  • Golang

    Golang

  • Redis

    Redis

  • Kafka

    Kafka

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

#go

#idempotency

#consumer

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

  • Аватар

    Golang Guru

    Maxim Lukyanov

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