Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Задачи

Войти

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

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

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Postgres: sharding, scaling, performance

Что такое шардирование и зачем оно нужно?

Знание шардирования

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

Шардирование — это разделение таблицы или базы на независимые части (шарды), обычно по user_id или дате. Это позволяет масштабировать систему горизонтально.

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

Шардирование применяется, когда объём данных выходит за рамки возможностей одной машины. Данные делятся между несколькими независимыми хранилищами (шардами), и приложение направляет запросы в нужный шард.

Способы:

  • По user_id % N — равномерное распределение по числу шардов.

  • По дате — логическое деление по времени.

Плюсы:

  • масштабируемость;

  • снижение нагрузки на одну БД;

  • возможность распараллеливания.

Минусы:

  • сложность обработки глобальных запросов;

  • необходимость маршрутизации на уровне приложения;

  • поддержание уникальности ID.

Для последнего часто используют UUID или Snowflake.

  • Аватар

    Golang Guru

    Maxim Lukyanov

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

Уровень

  • Рейтинг:

    5

  • Сложность:

    6

Навыки

  • Postgres

    Postgres

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

#sharding

#scaling

#performance

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

  • Аватар

    Golang Guru

    Maxim Lukyanov

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