Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Задачи

Войти

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

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

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Golang: saga, event, sourcing, 2pc, eventual, consistency, cdc

Как обеспечить согласованность данных между микросервисами?

Проверяет знание подходов к поддержанию целостности данных в распределённой системе.

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

Для согласованности используют транзакции на уровне бизнес-процессов (saga), где каждый шаг либо компенсируется при ошибке, двухфазное подтверждение (2PC) или eventual consistency через публикацию событий (Event Sourcing, CDC). Saga-паттерн более гибок и масштабируем, но требует реализации компенсационных операций.

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

Saga-паттерн:

- Последовательность локальных транзакций с компенсациями.

- Choreography: каждый сервис слушает события и сам выполняет шаг.

- Orchestration: централизованный координатор управляет шагами и откатами.

 

Two-Phase Commit (2PC):

- Централизованный менеджер координаторов, сильная согласованность, но низкая отказоустойчивость.

 

Eventual Consistency:

- Публикация событий (Kafka) при изменении состояния.

- Сервисы обновляют собственные копии данных асинхронно.

 

Change Data Capture (CDC):

- Реакция на изменения в БД и трансляция их в события.

 

Выбор подхода:

- Критичные операции → 2PC или Orchestration Saga.

- Высокая нагрузка и частичные разрешения → Choreography Saga, Eventual Consistency.

  • Аватар

    Golang Guru

    Maxim Lukyanov

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

Уровень

  • Рейтинг:

    1

  • Сложность:

    8

Навыки

  • Golang

    Golang

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

#saga

#event

#sourcing

#2pc

#eventual

#consistency

#cdc

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

  • Аватар

    Golang Guru

    Maxim Lukyanov

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