Мониторинг активных сессий PostgreSQL в Grafana: практическое руководство

Для эффективного мониторинга и анализа производительности PostgreSQL, предлагается использовать Grafana для визуализации истории активных сессий. Подход включает в себя создание партиционированной таблицы pg_stat_activity_history, которая регулярно пополняется данными из pg_stat_activity, фиксируя состояние сессий, их запросы и время ожидания. Партиционирование таблицы по времени обеспечивает более эффективное управление данными и их удаление.
Мониторинг активных сессий PostgreSQL в Grafana: практическое руководство
Изображение носит иллюстративный характер

Для автоматизации сбора данных и управления партициями используется pg_cron, который запускает фоновые задания. Создаются функции для создания новых партиций на 10 дней вперед и удаления старых, с заданным интервалом. Для сбора данных создается функция, которая с интервалом 10 секунд сбрасывает данные по активным сессиям в таблицу pg_stat_activity_history, учитывая состояние и продолжительность запросов.

Визуализация в Grafana представляет собой графики, отображающие количество сессий с разными типами ожидания во времени, а также таблицу со списком выполняемых запросов, их средней активностью и временем выполнения. Графики построены таким образом, что показывают накопленное количество сессий. Выпадающий список в Grafana позволяет фильтровать графики и таблицу по типам ожиданий.

Для использования данного решения необходимо импортировать дашборд в Grafana, предварительно настроив подключение к Postgres и создав таблицу pg_stat_activity_history по предоставленным скриптам. Это позволит администраторам БД быстро выявлять проблемные моменты и отслеживать производительность PostgreSQL с использованием инструментов мониторинга.


Новое на сайте

19213Трансформация первой линии SOC: три шага к предиктивной безопасности 19212Архитектура смыслов в профессиональной редактуре 19209Как беспрецедентный бунт чернокожих женщин в суде Бостона разрушил планы рабовладельцев? 19208Как новые поколения троянов удаленного доступа захватывают системы ради кибершпионажа и... 19207Почему мировые киберпреступники захватили рекламные сети, и как Meta вместе с властями... 19206Как фальшивый пакет StripeApi.Net в NuGet Gallery незаметно похищал финансовые API-токены... 19205Зачем неизвестная группировка UAT-10027 внедряет бэкдор Dohdoor в системы образования и... 19204Ритуальный предсвадебный плач как форма протеста в традиционном Китае 19203Невидимая угроза в оперативной памяти: масштабная атака северокорейских хакеров на... 19202Как уязвимость нулевого дня в Cisco SD-WAN позволяет хакерам незаметно захватывать... 19201Как Google разрушил глобальную шпионскую сеть UNC2814, охватившую правительства 70 стран... 19200Как простое открытие репозитория в Claude Code позволяет хакерам получить полный контроль... 19199Зачем киберсиндикат SLH платит женщинам до 1000 долларов за один телефонный звонок в...
Ссылка