Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Задачи

Войти

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

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

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

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

Почему нельзя полагаться только на уникальный индекс для реализации идемпотентности?

Проверяет понимание идемпотентности, конкурентных запросов и бизнес-инвариантов.

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

Уникальный индекс помогает избежать дублирования данных, но не гарантирует корректную идемпотентность бизнес-операции. Между проверкой и записью могут возникать гонки, а часть побочных эффектов уже может быть выполнена.

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

Многие разработчики считают, что достаточно создать уникальный индекс:

CREATE UNIQUE INDEX idx_order_id ON orders(order_id);

и проблема идемпотентности решена.

На практике это не так.

Представим сценарий:

  1. Приходит запрос на создание заказа.

  2. Заказ успешно создаётся.

  3. После этого отправляется событие в Kafka.

  4. Сервис падает.

  5. Клиент делает повторный запрос.

Уникальный индекс защитит таблицу от дубля заказа, но:

  • событие может быть отправлено повторно;

  • письмо пользователю может уйти второй раз;

  • деньги могут списаться повторно.

Поэтому идемпотентность обычно строится через:

  • idempotency key;

  • таблицу обработанных операций;

  • outbox pattern;

  • атомарную запись результата операции.

Пример:

CREATE TABLE idempotency_keys (
		key TEXT PRIMARY KEY,
		response JSONB
);

При повторном запросе возвращается сохранённый результат.

Вывод:

Уникальный индекс - это лишь один из инструментов идемпотентности, но не полноценное решение.

  • Аватар

    Golang Guru

    Maxim Lukyanov

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

Уровень

  • Рейтинг:

    4

  • Сложность:

    7

Навыки

  • Golang

    Golang

  • Postgres

    Postgres

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

#idempotency

#transaction

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

  • Аватар

    Golang Guru

    Maxim Lukyanov

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