Логотип YeaHub

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

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

Тренажёр

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

Обучение

Навыки

Задачи

Войти

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

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

© 2026 YeaHub

AI info

Карта сайта

Документы

Медиа

Назад
Вопрос про Postgres: sql, performance, tuning, explain

Как найти "тяжёлые" SQL-запросы без метрик?

Проверяет навыки диагностики производительности БД.

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

  1. Анализ медленных логов БД (PostgreSQL: log_min_duration_statement).

  2. Мониторинг активных запросов через pg_stat_activity.

  3. Использовать EXPLAIN ANALYZE для подозрительных запросов.

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

Шаги диагностики:

  1. Включить лог медленных запросов:

    -- PostgreSQL
    ALTER SYSTEM SET log_min_duration_statement = '1000'; -- Логировать запросы >1 сек
    SELECT pg_reload_conf();
  2. Поиск активных "тяжёлых" запросов:

    SELECT query, state, now() - query_start AS duration 
    FROM pg_stat_activity 
    WHERE state = 'active' AND duration > interval '5 seconds';
  3. Анализ плана выполнения:

    EXPLAIN ANALYZE 
    SELECT * FROM books WHERE author_id IN (SELECT id FROM authors WHERE name LIKE 'A%');
    • Ищите операции Seq Scan (полный перебор), Nested Loop.

Ручной профилинг в приложении:

// Логировать время выполнения запросов в коде
long start = System.currentTimeMillis();
ResultSet rs = statement.executeQuery();
log.info("Query time: {} ms", System.currentTimeMillis() - start);

Вывод: Комбинация логов БД и ручного анализа выявляет узкие места.

  • Аватар

    Golang Guru

    Maxim Lukyanov

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

Уровень

  • Рейтинг:

    2

  • Сложность:

    5

Навыки

  • Postgres

    Postgres

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

#sql

#performance

#tuning

#explain

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

  • Аватар

    Golang Guru

    Maxim Lukyanov

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