Инструменты VictoriaMetrics#
Настройка и использование VictoriaMetrics#
VictoriaMetrics - это система мониторинга и управления производительностью, которая позволяет отслеживать и анализировать метрики, события и журналы приложений и инфраструктуры. Предоставляет инструменты для визуализации данных, создания уведомлений и автоматического реагирования на проблемы. VictoriaMetrics может быть интегрирована с различными системами и инструментами, такими как Prometheus, Grafana и другими, что позволяет собирать и анализировать данные из различных источников.
VictoriaMetrics может быть установлена с помощью VictoriaMetrics-operator, который упрощает установку, масштабирование и обновление экземпляров VictoriaMetrics в кластере DropApp.
VictoriaMetrics предоставляет следующие инструменты:
vmctl- утилита командной строки, которая позволяет управлять компонентами VictoriaMetrics, такими как создание, удаление и обновление nodes, хранения данных, а также управление агентами сбора данных;vmrestore- утилита командной строки, которая позволяет восстановить данные из резервной копии VictoriaMetrics;vmauth- утилита командной строки, которая позволяет управлять аутентификацией и авторизацией в VictoriaMetrics;vmagent- агент сбора данных, который устанавливается на хостах или серверах, откуда необходимо собирать метрики и события;vmalert- утилита командной строки, которая позволяет управлять оповещениями в VictoriaMetrics;vmbackup- утилита командной строки, которая позволяет создавать резервные копии данных VictoriaMetrics.
Сценарии использования VictoriaMetrics#
VictoriaMetrics#
Для выполнения данного сценария необходимы права администратора, а также установленный Helm.
Примечание
В сценарии используется менеджер пакетов Helm. Данный инструмент не входит в состав продукта и требует дополнительной установки.
Добавьте репозиторий VictoriaMetrics для установки компонентов, выполнив команду:
Copyhelm repo add vm https://<repoexample.ru>/helm-charts/ # Укажите актуальный путь до локального репозиторияОбновите репозиторий Helm:
Copyhelm repo updateПроверьте корректность настроек, введите команду:
Copyhelm search repo vm/Вывод будет следующим:
NAME CHART VERSION APP VERSION DESCRIPTION vm/victoria-metrics-agent 0.7.20 v1.87.6 Victoria Metrics Agent - collects metrics from ... vm/victoria-metrics-alert 0.3.34 v1.87.6 Victoria Metrics Alert - executes a list of giv... vm/victoria-metrics-auth 0.2.23 v1.87.6 Victoria Metrics Auth - is a simple auth proxy ... vm/victoria-metrics-cluster 0.8.32 v1.87.6 Victoria Metrics Cluster version - high-perform... vm/victoria-metrics-k8s-stack 0.2.9 v1.87.6 Kubernetes monitoring on VictoriaMetrics stack.... vm/victoria-metrics-operator 0.1.17 0.32.0 Victoria Metrics Operator vm/victoria-metrics-single 0.7.5 v1.87.6 Victoria Metrics Single version - high-performa...Установите кластер VictoriaMetricss с помощью Helm. Для переопределения образов для Helm можно использовать флаг
--setв командеhelm install:cat <<EOF | helm install vmcluster vm/victoria-metrics-cluster -f - vmselect: podAnnotations: prometheus.io/scrape: "true" prometheus.io/port: "8481" vminsert: podAnnotations: prometheus.io/scrape: "true" prometheus.io/port: "8480" vmstorage: podAnnotations: prometheus.io/scrape: "true" prometheus.io/port: "8482" EOFЗапуск команды
helm install vmcluster vm/victoria-metrics-clusterустанавливает кластер VictoriaMetrics в namespace по умолчанию внутри созданного кластера.Команда
podAnnotations: prometheus.io/scrape: "true"иpodAnnotations:prometheus.io/port: "some_port"запускает сбор метрик из podvmselect,vminsertиvmstorageи из их портов.Вывод будет следующим:
NAME: vmcluster LAST DEPLOYED: Thu Jun 1 09:41:57 2023 NAMESPACE: default STATUS: deployed REVISION: 1 TEST SUITE: None NOTES: Write API:Примечание
Все образы в манифестах пользователей будут содержать информацию из registry DropApp.
Получите URL-адрес службы вставки
vminsertVictoriaMetrics, выполнив команды:export POD_NAME=$(kubectl get pods --namespace default -l "app=vminsert" -o jsonpath="{.items[0].metadata.name}") kubectl --namespace default port-forward $POD_NAME 8480Обновите файл конфигурации Prometheus и добавьте в него следующие строки:
prometheus.yml remote_write: - URL: "http://<insert-service>/insert/0/prometheus/"Получите доступ к API VictoriaMetrics через порт 8481 со следующим DNS-именем из кластера:
vmcluster-victoria-metrics-cluster-vmselect.default.svc.cluster.localПолучите URL-адрес службы VictoriaMetrics, выполнив команду:
export POD_NAME=$(kubectl get pods --namespace default -l "app=vmselect" -o jsonpath="{.items[0].metadata.name}") kubectl --namespace $POD_NAME 8481Укажите URL-адрес службы в Grafana:
Примечание
В качестве источника данных необходимо выбрать Prometheus.
Введите это поле URL в Grafana:
http://<select-service>/select/0/prometheus/Убедитесь, что pods кластера VictoriaMetrics запущены и работают, выполнив следующую команду:
kubectl get pods
Вывод будет следующим:
~~~bash
NAME READY STATUS RESTARTS AGE
vmcluster-victoria-metrics-cluster-vminsert-689cbc8f55-95szg 1/1 Running 0 16m
vmcluster-victoria-metrics-cluster-vminsert-689cbc8f55-f852l 1/1 Running 0 16m
vmcluster-victoria-metrics-cluster-vmselect-977d74cdf-bbgp5 1/1 Running 0 16m
vmcluster-victoria-metrics-cluster-vmselect-977d74cdf-vzp6z 1/1 Running 0 16m
vmcluster-victoria-metrics-cluster-vmstorage-0 1/1 Running 0 16m
vmcluster-victoria-metrics-cluster-vmstorage-1 1/1 Running 0 16m
~~~
Установите
vmagentиз Helm, выполните следующую команду:
helm install vmagent vm/victoria-metrics-agent -f https://<repoexample.ru>.ru/guides/victoriametrics.yaml
# Укажите актуальный путь до локального репозитория
Полное содержание файла victoriametrics.yaml:
~~~~~{dropdown} victoriametrics.yaml
:icon: code
~~~{literalinclude} /examples/victoriametrics.yaml
:language: yaml
~~~
~~~~~
Где remoteWriteUrls: - http://vmcluster-victoria-metrics-cluster-vminsert.default.svc.cluster.local:8480/insert/0/prometheus/ настраивает vmagent для записи очищенных метрик в файл vmselect service.
Вторая часть этого yaml-файла добавляет раздел metric_relabel_configs, выводит метрики на панели управления Grafana.
Выполните команду и убедитесь, что
vmagentзапущен:
kubectl get pods | grep vmagent
Вывод отобразит следующее:
~~~bash
vmagent-victoria-metrics-agent-69974b95b4-mhjph 1/1 Running 0 11m
~~~
Добавьте репозиторий Grafana:
Copyhelm repo add grafana https://<repoexample.ru>/helm-charts
helm repo update
# Укажите актуальный путь до локального репозитория
Добавьте источник данных VictoriaMetrics с названием релиза
my-grafana:
my-grafana.yaml
cat <<EOF | helm install my-grafana grafana/grafana -f -
datasources:
datasources.yaml:
apiVersion: 1
datasources:
- name: victoriametrics
type: prometheus
orgId: 1
url: http://vmcluster-victoria-metrics-cluster-vmselect.default.svc.cluster.local:8481/select/0/prometheus/
access: proxy
isDefault: true
updateIntervalSeconds: 10
editable: true
dashboardProviders:
dashboardproviders.yaml:
apiVersion: 1
providers:
- name: 'default'
orgId: 1
folder: ''
type: file
disableDeletion: true
editable: true
options:
path: /var/lib/grafana/dashboards/default
dashboards:
default:
victoriametrics:
gnetId: 11176
revision: 18
datasource: victoriametrics
vmagent:
gnetId: 12683
revision: 7
datasource: victoriametrics
kubernetes:
gnetId: 14205
revision: 1
datasource: victoriametrics
EOF
В результате применения манифеста выполнена следующая последовательность:
* установлена **Grafana** из репозитория **Helm**;
* подготовлен источник данных **VictoriaMetrics** с URL-адресом из шага 4;
* добавлена информационная панель **VictoriaMetrics**: `https://<repoexample.ru>m/grafana/dashboards/11176-victoriametrics-cluster/`;
* добавлена информационная панель для агента **VictoriaMetrics**: `https://<repoexample.ru>/grafana/dashboards/12683-victoriametrics-vmagent/`;
* добавлена панель мониторинга для наблюдения метрик кластера DropApp: `https://<repoexample.ru>/grafana/dashboards/14205-kubernetes-cluster-monitoring-via-prometheus/`.
Просмотрите журнал вывода, скопируйте, вставьте и запустите адреса из шага 14.
Чтобы получить пароль администратора Grafana, выполните команду:
kubectl get secret --namespace default my-grafana -o jsonpath="{.data.admin-password}" | base64 --decode ; echo
Сохраните пароль в файл на компьютере.
Чтобы получить доступ к сервису Grafana в веб-браузере, выполните следующую команду:
export POD_NAME=$(kubectl get pods --namespace default -l "app.kubernetes.io/name=grafana,app.kubernetes.io/instance=my-grafana" -o jsonpath="{.items[0].metadata.name}")
Используйте команду для прослушивания порта
3000на pod с именем, указанным в переменной окруженияPOD_NAME:
kubectl --namespace default port-forward $POD_NAME 3000
Откройте в браузере
http://127.0.0.1:3000/dashboardsи выберите панель мониторингаCluster Monitoring (via Prometheus). Используйте логинadminдля входа и пароль который был получен в шаге 15.
В выводе будет отображаться страница с метриками использования памяти, процессора и файловой системы кластера.
VictoriaMetrics-operator#
VictoriaMetrics-operator - инструмент для управления конфигурацией мониторинга приложений в DropApp. У VictoriaMetrics-operator есть возможности API.
Существует поддержка CRD (Custom Resource Definition) VictoriaMetrics:
VMServiceScrape- определяет конфигурацию метрик извлечения из модулей, поддерживаемых сервисами;VMPodScrape- определяет конфигурацию извлечения метрик из pods;VMRule- определяет правила оповещения или записи;VMProbe- отслеживает состояние виртуальных машин, таких как загрузка процессора, использование памяти и дискового пространства.VMProbeтакже может использоваться для установки и настройки сетевых интерфейсов и управления питанием виртуальных машин.
VictoriaMetrics-operator управляет приложениями VictoriaMetrics внутри кластера DropApp и упрощает быстрый запуск этого процесса. С помощью CRD определите конфигурацию приложения и примените ее к CRD-объектам кластера.
VictoriaMetrics-operator имеет возможность делегировать настройку мониторинга приложений конечным пользователям.
Определите конфигурацию очистки метрик и предупреждений app_deployment.yaml, app_vmpodscrape.yaml и app_vmrule.yaml, примените их к кластеру DropApp:
Определите ресурсы:
kubectl apply -f release/crdsСоздайте RBAC для оператора, соответствующую конфигурацию для выпуска можно найти в файле
release/operator/rbac.yaml. Этот файл описывает роль пользователя DropApp, который предоставляет RBAC, управление доступом на основе ролей для ресурсов DropApp.Измените конфигурацию для VictoriaMetrics-operator в
release/operator/manager.yamlи примените, используя команду:kubectl apply -f release/operator/manager.yamlПроверьте статус оператора:
kubectl get pods -n monitoring-systemВывод будет следующим:
NAME READY STATUS RESTARTS AGE vm-operator-667dfbff55-cbvkf 1/1 Running 0 1sВывод отображает информацию о состоянии виртуальной машины. Каждый столбец представляет собой определенную характеристику виртуальной машины:
NAME- имя виртуальной машины;READY- статус готовности виртуальной машины. В данном случае, значение1означает, что виртуальная машина готова к использованию;STATUS- текущее состояние виртуальной машины. В этом случае значениеRunningозначает, что виртуальная машина работает;RESTARTS- количество раз, когда виртуальная машина была перезапущена. В данном случае значение0означает, что перезапусков не было;AGE- время, прошедшее с момента создания виртуальной машины. В данном случае это значение 1s (1 секунда), так как виртуальная машина была создана только что.
VictoriaMetrics-cluster#
VictoriaMetrics-cluster - это система мониторинга и управления событиями, которая позволяет собирать, хранить и анализировать метрики и события из различных источников.
VictoriaMetrics-cluster состоит из следующих сервисов:
vmstorage— сохраняет необработанные данные и возвращает запрошенные данные в заданном диапазоне времени для заданных фильтров меток;vminsert— принимает полученные данные и распределяет их между nodesvmstorageв соответствии с последовательным хешированием имени метрики и всех ее меток;vmselect— выполняет входящие запросы, извлекая необходимые данные со всех настроенных nodesvmstorage.
Config-reloader#
Config-reloader — это альтернативная версия prometheus-config-reloaded. Основное отличие заключается в возможности считывать Secret напрямую из DropApp и записывать его в локальную файловую систему. Это ускоряет процесс перезагрузки конфигурации и делает его более предсказуемым.
Синхронизация конфигурации#
Основные понятия#
Приложения VictoriaMetrics, как и многие другие приложения с файлом конфигурации, развернутые в Kubernetes, используют ConfigMaps и Secrets для файлов конфигурации. Обычно приложения не отслеживают изменений конфигурации. Приложения перезагружают свою конфигурацию по сигналу от пользователя или другого инструмента, который умеет следить за обновлениями. В Kubernetes для этого случая наиболее популярным решением является sidecar-контейнер, который следит за изменениями конфигурационного файла и отправляет HTTP-запрос приложению.
Configmap или Secret, установленный в pod, хранит копию его содержимого. Компонент Kubelet, входящий в DropApp, отвечает за синхронизацию содержимого между объектом в Kubernetes API и файлом на диске. Синхронизировать содержимое сразу неэффективно, и Kubelet со временем синхронизирует его. Существует конфигурационная опция, которая управляет этим периодом.
Поэтому приложения, управляемые оператором, получают изменения не сразу. Обычно проходит 1-2 минуты, прежде чем содержимое будет обновлено.
Могут возникать ошибки, когда приложение было удалено, но vmagent все равно пытается его отсканировать.
Включение config-reloader#
Решение таких ошибок — уменьшение периода синхронизации. Оно настраивается глобально и может быть сложным для пользователя.
Для обновления Configmap оператор изменяет аннотацию со временем обновления содержимого Configmap. Это немедленно запускает синхронизацию содержимого ConfigMap агентом Kubelet. Это касается vmalert, он использует ConfigMap в качестве источника конфигурации.
Однако это не работает для Secret. Оператор предлагает свою реализацию для sidecar-контейнера. Его можно настроить с помощью переменной env для оператора:
- name: VM_USECUSTOMCONFIGRELOADER
value: "true"
Если это условие задано, оператор использует свой собственный Config-reloader вместо prometheus-config-reload.
Он отслеживает изменения в соответствующем Secret с помощью Kubernetes API, отслеживает вызовы и записывает содержимое в emptyDir. Этот пустой каталог используется совместно с приложением. В случае изменений содержимого config-reloader отправляет HTTP-запросы в приложение. Это значительно сокращает время синхронизации конфигурации.
Для включения config-reloader добавьте в команду на запуск контейнера в манифесте компонентов VictoriaMetrics:
containers:
- name: config-reloader
command:
- /usr/local/bin/config-reloader