Чем saga pattern отличается от distributed transaction и когда что выбрать?
Что хотят услышать интервьюеры:
Сравнение: saga pattern стоит сравнивать с distributed transaction по критериям читаемости, безопасности, производительности, тестируемости и поддержки командой.
Ответ:
Когда выбирать saga pattern: когда его свойства прямо соответствуют задаче: saga координирует распределенный бизнес-процесс без 2PC.
Слабый ответ: “так принято в Spring/Java”. На собеседовании лучше объяснить ограничения и цену выбора.
// local transactions + compensating actions