Как правильно применять дубли сообщений Kafka в реальном Java/Spring проекте?
Что хотят услышать интервьюеры:
Практический подход: используйте дубли сообщений Kafka там, где он решает конкретную задачу, а не ради моды.
- Определите слой: domain, application, infrastructure или API.
- Проверьте влияние на транзакции, потокобезопасность, тесты и поддержку.
- Зафиксируйте контракт через тест или явно описанный API.
Ответ:
На собеседовании: сильный ответ показывает trade-off и production-последствия. Риск: считать, что Kafka гарантирует exactly-once для всей бизнес-операции.
// idempotent consumer + offset commit after processing