Управление метриками
Система мониторинга платформы основана на метриках, собираемых Prometheus / VictoriaMetrics. В этом документе описано, как управлять этими метриками.
Содержание
Просмотр метрик, предоставляемых компонентами платформыПросмотр всех метрик, хранящихся в Prometheus / VictoriaMetricsПредварительные условияПроцедурыПросмотр всех встроенных метрик, определённых платформойПредварительные условияПроцедурыИнтеграция внешних метрикПредварительные условияПроцедурыПросмотр метрик, предоставляемых компонентами платформы
Метод мониторинга компонентов кластера внутри платформы заключается в извлечении метрик, предоставляемых через ServiceMonitor. Метрики в платформе доступны публично через эндпоинт /metrics. Вы можете просмотреть метрики конкретного компонента платформы, используя следующий пример команды:
Пример вывода:
Просмотр всех метрик, хранящихся в Prometheus / VictoriaMetrics
Вы можете просмотреть список доступных метрик в кластере, чтобы помочь вам написать необходимый PromQL на основе этих метрик.
Предварительные условия
-
У вас есть ваш пользовательский Token
-
У вас есть адрес платформы
Процедуры
Выполните следующую команду для получения списка метрик с помощью команды curl:
Пример вывода:
Просмотр всех встроенных метрик, определённых платформой
Для упрощения использования пользователями платформа встроила большое количество часто используемых метрик. Вы можете напрямую использовать эти метрики при настройке оповещений или панелей мониторинга без необходимости определять их самостоятельно. Ниже описано, как просмотреть эти метрики.
Предварительные условия
-
У вас есть ваш пользовательский Token
-
У вас есть адрес платформы
Процедуры
Выполните следующую команду для получения списка метрик с помощью команды curl:
Пример вывода:
- Поддерживает ли эта метрика настройку оповещений
- Поддерживает ли эта метрика использование в панелях мониторинга
- Поддерживает ли эта метрика настройку оповещений для нескольких ресурсов
- Определённое для метрики выражение PromQL
- Переменные, которые можно использовать в выражении PromQL метрики
Интеграция внешних метрик
Помимо встроенных метрик платформы, вы также можете интегрировать метрики, предоставляемые вашими приложениями или сторонними приложениями через ServiceMonitor или PodMonitor. В этом разделе в качестве примера используется Elasticsearch Exporter, установленный в виде pod в том же кластере.
Предварительные условия
Вы установили ваше приложение и открыли метрики через указанные интерфейсы. В этом документе предполагается, что ваше приложение установлено в пространстве имён cpaas-system и открыло эндпоинт http://<elasticsearch-exporter-ip>:9200/_prometheus/metrics.
Процедуры
-
Создайте Service/Endpoint для Exporter, чтобы открыть метрики
-
Создайте объект
ServiceMonitorдля описания метрик, предоставляемых вашим приложением:- К какому Prometheus должен быть синхронизирован ServiceMonitor; оператор будет слушать соответствующий ресурс ServiceMonitor на основе конфигурации serviceMonitorSelector в Prometheus CR. Если метки ServiceMonitor не соответствуют конфигурации serviceMonitorSelector Prometheus CR, этот ServiceMonitor не будет мониториться оператором.
- В каких пространствах имён ServiceMonitor будет слушать оператор на основе конфигурации serviceMonitorNamespaceSelector в Prometheus CR; если ServiceMonitor не находится в serviceMonitorNamespaceSelector Prometheus CR, этот ServiceMonitor не будет мониториться оператором.
- Метрики, собираемые Prometheus, будут иметь метку job, значение которой соответствует значению метки сервиса, указанной в jobLabel.
- ServiceMonitor сопоставляется с соответствующим Service на основе конфигурации namespaceSelector.
- ServiceMonitor сопоставляется с Service на основе конфигурации selector.
- ServiceMonitor сопоставляется с портом Service на основе конфигурации port.
- Путь доступа к Exporter, по умолчанию /metrics.
- Интервал, с которым Prometheus опрашивает метрики Exporter.
- Если для доступа к пути Exporter требуется аутентификация, необходимо добавить данные аутентификации; также поддерживаются bearer token, tls аутентификация и другие методы.
-
Проверьте, мониторится ли ServiceMonitor Prometheus
Зайдите в UI компонента мониторинга и проверьте, существует ли задача
cpaas-elasticsearch-exporter.- Адрес UI Prometheus:
https://<Your platform access address>/clusters/<Cluster name>/prometheus-0/targets - Адрес UI VictoriaMetrics:
https://<Your platform access address>/clusters/<Cluster name>/vmselect-ui/vmui/?#/metrics
- Адрес UI Prometheus: