Как правильно применять Kafka transactions в реальном Java/Spring проекте?
Что хотят услышать интервьюеры:
Практический подход: используйте Kafka transactions там, где он решает конкретную задачу, а не ради моды.
- Определите слой: domain, application, infrastructure или API.
- Проверьте влияние на транзакции, потокобезопасность, тесты и поддержку.
- Зафиксируйте контракт через тест или явно описанный API.
Ответ:
На собеседовании: сильный ответ показывает trade-off и production-последствия. Риск: ожидать единой транзакции Kafka + PostgreSQL без отдельной стратегии.
// transactional producer for consume-process-produce