Глава 2. Архитектура

pgpro-otel-collector основан на архитектуре OpenTelemetry Collector и состоит из нескольких компонентов, которые взаимодействуют друг с другом по конвейерному принципу (сбор — обработка — отправка):

  • Ресиверы — ключевые компоненты, отвечающие за сбор данных. pgpro-otel-collector включает следующие ресиверы:

    • postgrespro — главный компонент коллектора, заключающий в себе все инструменты (встроенные плагины) для сбора данных с экземпляра БД.

    • filelog — вспомогательный ресивер, отвечающий за сбор информации из журналов активности БД.

    • hostmetrics — вспомогательный ресивер для сбора информации из операционной системы. Могут потребоваться права root.

  • Процессоры принимают и обрабатывают данные от ресиверов. pgpro-otel-collector включает следующие процессоры:

    • attributes обрабатывает отдельные атрибуты записей журнала.

    • resource добавляет дополнительные атрибуты записей журнала.

    • batch формирует пакеты данных и регулирует механизм отправки данных.

  • Экспортёры получают обработанные данные от процессоров и доставляют их внешним потребителям. pgpro-otel-collector включает следующие экспортёры:

    • otlphttp экспортирует и отправляет данные по протоколу OTLP (стандартный протокол OpenTelemetry, внедряемый многими поставщиками систем мониторинга) с использованием протокола HTTP.

    • prometheus экспортирует метрики по встроенному HTTP-серверу и публикует их на странице /metrics в формате системы мониторинга Prometheus. prometheus используется по умолчанию, так как не требует дополнительной настройки.

Согласно общей архитектуре OpenTelemetry Collector, pgpro-otel-collector можно настроить таким образом, чтобы один и тот же компонент использовался несколько раз. Например, можно использовать несколько экземпляров одного и того же ресивера для сбора данных с нескольких экземпляров СУБД. Также один и тот же экспортёр может использоваться для отправки данных в разные хранилища.