2. Установка РБДМонитор

Доступно несколько способов установки:

2.1. RPM-пакет

  1. Скачайте с официального сайта rpm-пакеты серверной и клиентской части РБДМонитор.

  2. Установите серверную часть РБДМонитор:

    dnf install <путь_до_rpm_пакета_rdbmonitor-server>
    
  3. Установите РЕД Базу Данных для серверной части, следуя инструкции в Руководстве администратора.

  4. Установите клиентскую часть РБДМонитор:

    dnf install <путь_до_rpm_пакета_rdbmonitor-client>
    
  5. Настройте РБДМонитор по инструкции.

2.2. Установка из архива

  1. Скачайте установочный архив для клиентской части с официального сайта. После скачивания распакуйте архив, выполнив команду:

    tar -xzf <архив>
    
  2. Установите клиентскую часть, выполнив install.sh с правами администратора:

    sudo ./install.sh -o install -p client
    
  3. Скачайте установочный архив для серверной части с официального сайта. После скачивания распакуйте архив, выполнив команду:

    tar -xzf <архив>
    
  4. Установите плагины redsoft-rdbmonitor-app и redsoft-reddatabase-datasource командой:

    sudo ./install.sh -o install -p grafana_plugins
    

    При установке плагинов для нужно внести redsoft-rdbmonitor-app и redsoft-reddatabase-datasource в список доверенных, разрешив редактировать файл /etc/grafana/grafana.ini.

  5. Установите Loki:

    sudo ./install.sh -o install -p loki
    
  6. Настройте РБДМонитор по инструкции.

3. Настройка РБДМонитор

  1. Запустите РЕД Базу Данных:

    systemctl start firebird
    
  1. Скорректируйте скрипт create_tables.sql, расположенный по пути /opt/rdbmonitor/server/rdb/create_tables.sql. По умолчанию база данных пользовательских запросов (statements.fdb) будет создана по пути /db/statemens.fdb. По умолчанию доступ к СУБД с базой данных пользовательских запросов осуществляется по порту 3050.

    Выполните скрипт:

    /opt/RedDatabase/bin/isql -user <имя пользователя> -password <пароль> -i /opt/rdbmonitor/server/rdb/create_tables.sql
    
  2. Установите асинхронный режим записи на диск:

    gfix -write async <база данных statements.fdb>
    
  3. Запустите Loki:

    sudo systemctl start loki.service
    
  4. Укажите настройки Prometheus в файле /etc/prometheus/prometheus.yml:

    global:
      scrape_interval: <интервал сбора метрик><единицы измерения s/m/h>
      scrape_timeout: <время ожидания получения в секунду>
    
    scrape_configs:
      - job_name: "RDBMonitor"
        static_configs:
          - targets: ["<хост>:<порт>", ..., "<хост>:<порт>"]
    
    rule_files:
      - rules.yml
    
    # alerting:
    #   alertmanagers:
    #     - static_configs:
    #       - targets: ["localhost:9093"]
    

    Параметр scrape_interval определяет, как часто нужно собирать метрики. Допустимые единицы измерения: s - секунды, m - минуты, h - часы.

    Параметр scrape_timeout устанавливает время ожидания получения метрик.

    Предупреждение

    Параметр job_name задаёт имя группы экспортёров. Экспортёры, входящие в группу, определяются в параметре targets. Изменять значение параметра job_name нельзя.

    Параметр targets определяет сетевые узлы экспортёров, к которым будет обращаться Prometheus для сбора метрик. Портом экспортёра по умолчанию является 3051.

    В секции rule_files указывается список файлов с правилами, на соответствие которым нужно проверять собранные метрики. Файл rules.yml необходимо скопировать из /opt/RedMonitor/server/prometheus/ в корневой каталог Prometheus.

    Секция alerting определяет сущности Alertmanager, в которые Prometheus будет отправлять предупреждения, когда собранные метрики соблюдают правила, указанные в секции rule_files. Если нет необходимости в уведомлениях, то эту секцию нужно оставить закомментированной.

    Подробнее о настройке Prometheus см. документацию на официальном сайте.

  5. Запустите Prometheus:

    sudo systemctl start prometheus
    
  6. Предупреждение

    Если уведомления не нужны, то этот пункт можно пропустить.

    Для получения уведомлений укажите настройки Alertmanager в файле /etc/alertmanager/alertmanager.yml. Можно использовать готовый набор правил уведомлений, поставляемый вместе с РБДМонитор. Файлы rules.yml и cluster_rules.yml, расположенные по пути /opt/RedMonitor/server/prometheus/, Если уведомления не нужны, то этот пункт можно пропустить.

    После настройки запустите Alertmanager:

    sudo systemctl start alertmanager
    

    Более подробно о настройке Alertmanager можно узнать в официальной документации.

  7. Запустите Grafana:

    sudo systemctl start grafana-server
    
  8. Откройте в браузере страницу запущенной Grafana (по умолчанию http://localhost:3000/). По умолчанию для входа используется логин admin и пароль admin.

    Укажите источники данных:

    • Во вкладке Connections \(\to\) Data sources нажмите на кнопку Add data source. В открывшемся окне из списка источников выберите Prometheus. Укажите URL-адрес для доступа к Prometheus (по умолчанию http://localhost:9090/). Необходимо настроить интервал сбора метрик. Для параметра Scrape interval укажите число, совпадающее со значением параметра scrape_interval в конфигурационном файле Prometheus (prometheus.yml). Нажмите на кнопку Save & test.

    • Укажите источником базу данных, в которой хранятся пользовательские запросы. Для этого во вкладке Data sources нажмите на кнопку Add new data source. В открывшемся окне из списка источников выберите РЕД База Данных. Заполните поля для соединения с базой данных и нажмите на кнопку Save & test.

    • Во вкладке Data sources нажмите на кнопку Add data source. В открывшемся окне из списка источников выберите Loki, для сбора логов операционной системы и СУБД. Укажите URL-адрес для доступа к Loki (по умолчанию http://127.0.0.1:3100) и нажмите на кнопку Save & test.

  1. В корневом каталоге сервера, который необходимо мониторить, создайте конфигурационный файл агрегатного аудита запросов - aggtrace.conf, и укажите в нём следующие параметры:

    database
    {
        format = 3
        enabled = true
    }
    

    Опция enabled = true включает ведение аудита для сбора сбора данных о запросах.

    Опция format = 3 указывает, что нужно использовать агрегатный аудит.

  2. Для сервера, который необходимо мониторить, в firebird.conf укажите следующие настройки:

    TracePlugin = fbtrace, messagetrace
    AuditTraceConfigFiles = fbtrace.conf;aggtrace.conf
    
  3. У наблюдаемой СУБД включите плагин агрегатного аудита в plugins.conf:

    Plugin = messagetrace
    {
          Module = /opt/rdbmonitor/client/messagetrace
          Required = true
          Config = monitor_config
    }
    
    Config = monitor_config {
      ConfigFile = /opt/rdbmonitor/client/exporter/exporter_conf.json
    }
    
  4. Запустите РЕД Базу Данных:

    systemctl start firebird
    
  5. Укажите настройки экспортёра в файле /opt/rdbmonitor/client/exporter/exporter_conf.json.

    {
     "exporter": {
       "port": <порт экспортёра>,
       "rdb_lock_print": {
         "enabled": true
       },
       "scrape_system":{
         "enabled": false
       },
       "scrape_queries": {
         "enabled": true,
         "filters": "<путь к файлу с настройками фильтрации>",
         "default":
           {
              "shmem_size":<размер разделяемой памяти в МиБ>
           }
       },
       "scrape_mon_tables":{
         "enabled": true
       },
       "user_metrics": {
         "enabled": true,
         "timeout": <таймаут сбора метрики в секундах>,
         "max_metric_labels": <максимальное кол-во метрик>,
         "max_user_metrics": <максимальное кол-во пользовательских метрик>,
         "max_metric_data_blocks": <максимальное кол-во блоков метрики>
       }
     },
     "promtail": {
       "host": "<хост наблюдаемого сервера>"
     },
     "dictserver": {
       "host": "<хост базы данных>",
       "port": <порт базы данных>,
       "database": "/opt/rdbmonitor/server/rdb/statements.fdb",
       "user": "<пользователь>",
       "password": "<пароль>",
       "Auth_plugins": ["<плагин>", ..., "<плагин>"],
       "loki": {
         "port": <порт loki>
       }
     },
     "RedDatabase": {
       "host": "<хост СУБД>",
       "port": <порт СУБД>,
       "user": "<логин>",
       "password": "<пароль>",
       "folder_path": "<путь к папке установки RedDatabase>",
       "Auth_plugins": ["<плагин>", ..., "<плагин>"]
     },
     "databases": {
       "<псевдоним>": {
         "alias": "<алиас>",
         "scrape": {
           "enabled": true,
           "filters":"<путь к файлу с настройками фильтрации>",
           "shmem_size":<размер разделяемой памяти в МиБ>
         }
       }
     }
    }
    

    Значения строковых параметров должны заключаться в двойные кавычки. Значения для целочисленных параметров нужно указывать без кавычек.

    Параметры конфигурации:

    В секции exporter обязательно должны быть указаны все параметры, иначе экспортёр не запустится. Параметры секции:

    • port - Порт, на котором работает экспортёр, по умолчанию 3051. Параметр имеет целочисленный тип.

    • rdb_lock_print - Определяет, собирать ли данные файла блокировок. Аналогично rdb_lock_print -n -l -o -c. По умолчанию установлено значение true.

    • scrape_system - Определяет, собирать ли информацио об операционной системе. По умолчанию установлено значение true.

    • scrape_mon_tables - Определяет, собирать ли данные из таблиц мониторинга. По умолчанию установлено значение true.

    • scrape_queries - Определяет, собирать ли данные с помощью aгрегирующего трейса. По умолчанию установлено значение false. Агрегатный аудит необходимо предварительно настроить по инструкции.

      Опция shmem_size указывает размер разделяемой памяти в МиБ. Допустимы целочисленные значения от 128 до 1024. По умолчанию shmem_size = 128.

      Необязательная опция filters определяет путь к предварительно созданному файлу с настройками фильтрации filters.ini. Собираться будут только запросы, характеристики которых превышают хотя бы одно из указанных значений параметров в filters.ini. Например, если time = 100, то соберутся только запросы, выполняющиеся дольше 100 миллисекунд. Указанные здесь параметры фильтрации распостраняются на все отслеживаемые базы данных. Настроить фильтры для конкретной базы данных можно в секции databases.

      Структура filters.ini:

      [limits.statements]
      <параметр>
      ...
      <параметр>
      

      Параметры фильтрации:

      • time - время выполнения запроса в миллисекундах;

      • prepare - количество подготовленных запросов (событий prepare);

      • prepare failed - количество запросов, подготовка которых завершилась ошибкой;

      • start - количество запущенных запросов (событий start);

      • start failed - количество неудачно запустившихся запросов;

      • finish - количество завершённых запросов (событий finish);

      • finish failed - количество неудачно завершённых запросов;

      • free - количество освобождённых запросов (событий free);

      • free failed - количество неудачно освобождённых запросов;

      • reads - количество страниц, считанных с диска;

      • marks - количество отмеченных (mark) страниц;

      • writes - количество страниц, записанных на диск;

      • fetches - количество страниц, считанных из страничного кэша (fetch);

      • mem use by sort in total - количество байт, выделенных под сортировку;

      • mem use by sort in cache - количество байт, выделенных под сортировку в кеше;

      • mem use by sort in disk - количество байт, выделенных под сортировку на диске.

      Значения всех параметров фильтрации должны быть целым положительным числом.

      Пример настройки filters.ini, где будут собираться запросы, которые выполнялись дольше 60 секунд или более 100 раз

      [limits.statements]
      time = 60000
      finish = 100
      
    • user_metrics - определяет, собирать ли пользовательские метрики. По умолчанию выключено ("enabled": false). Опция timeout указывает таймаут в секундах, по истечении которого метрика перестанет запрашиваться, значение должно быть дробным числом (по умолчанию значение 0.1). Опция max_metric_labels определяет максимальное количество собираемых метрик (по умолчанию значение 5). Опция max_user_metrics максимальное количество пользовательских метрик (по умолчанию значение 100). Опция max_metric_data_blocks максимальное количество блоков метрики (по умолчанию значение 10).

    Секция promtail:

    • host - определяет ip-адрес устройства наблюдаемого сервера, указанное значение должно совпадать со значением в конфигурационном файле Prometheus. параметр имеет строковый тип.

    Секция dictserver:

    • host - определяет ip-адрес устройства, на котором работает база даннных для пользовательских запросов; параметр имеет строковый тип;

    • port - порт, на котором работает база даннных для пользовательских запросов, по умолчанию 3050; параметр имеет целочисленный тип;

    • database - псевдоним базы данных пользовательских запросов;

    • user - имя пользователя, от которого экспортёр будет подключаться к базе данных пользовательских запросов; параметр имеет строковый тип;

    • password - пароль пользователя для подключения к базе данных пользовательских запросов; параметр имеет строковый тип;

    • Auth_plugins - определяет список плагинов, которые используются для аутентификации при подключении к базе данных пользовательских запросов, в качестве разделителя используется запятая, каждый плагин должен заключаться в двойные кавычки; cписок заключается в квадратные скобки;

    • loki - определяет порт, на котором работает Loki. По умолчанию 3100.

    Секция RedDatabase:

    • host- определяет ip-адрес устройства, на котором работает наблюдаемая СУБД; параметр имеет строковый тип;

    • port - порт, на котором работает наблюдаемая СУБД; параметр имеет целочисленный тип;

    • login - имя пользователя, от которого экспортёр будет подключаться к СУБД. Желательно использовать пользователя с административными привилегиями для мониторинга всех подключений; параметр имеет строковый тип;

    • password - пароль пользователя; параметр имеет строковый тип;

    • folder_path - путь к установочной папке RedDatabase;

    • Auth_plugins - определяет список плагинов, которые экспортёр использует для аутентификации, в качестве разделителя используется запятая, каждый плагин должен заключаться в двойные кавычки; cписок заключается в квадратные скобки;

    Секция databases определяет список баз данных для мониторинга, указывающийся следующим образом:

    "databases": {
     "<псевдоним>": {
      "alias": "<алиас>",
      "scrape": {
        "enabled": true,
         "filters":"filters_employee.ini"
      }
     },
     ...
    }
    

    Где:

    • псевдоним - уникальный псевдоним базы данных;

    • alias - псевдоним базы данных, который используется СУБД;

    • enabled - логический параметр, определяющий отслеживать ли указанную базу данных;

    • filters - необязательная опция, которая определяет путь к предварительно созданному файлу с настройками фильтрации filters.ini. Собираться будут только запросы, характеристики которых превышают указанные значения параметров в filters.ini. Например, если time = 100, то соберутся только запросы, выполняющиеся дольше 100 миллисекунд. Параметры фильтрации распостраняются на указанную базу данных.

    Пример настроенного файла exporter_conf.json:

    {
         "exporter": {
            "port": 3051,
            "rdb_lock_print": {
               "enabled": true
            },
            "scrape_system": {
               "enabled": true
            },
            "scrape_queries": {
               "enabled": true,
               "filters": "/opt/rdbmonitor/client/exporter/filters.ini"
            },
            "scrape_mon_tables": {
               "enabled": true
            },
            "user_metrics": {
               "enabled": false,
               "timeout": 0.1,
               "max_metric_labels": 5,
               "max_user_metrics": 100,
               "max_metric_data_blocks": 10
            }
         },
         "promtail": {
            "host": "127.0.0.1"
         },
         "dictserver": {
            "host": "127.0.0.1",
            "port": 3050,
            "database": "/opt/rdbmonitor/server/rdb/statements.fdb",
            "user": "SYSDBA",
            "password": "masterkey",
            "Auth_plugins": ["Srp"],
            "loki": {
               "port": 3100
            }
         },
         "RedDatabase": {
            "host": "127.0.0.1",
            "port": 3050,
            "user": "SYSDBA",
            "password": "masterkey",
            "folder_path": "/opt/RedDatabase",
            "Auth_plugins": ["Srp"]
         },
         "databases": {
            "employee_db": {
               "alias": "employee",
                "scrape": {
                  "enabled": true,
                  "filters":"filters_employee.ini"
               }
            }
         }
      }
    
  6. Предупреждение

    Перед запуском экспортёра убедитесь, что РЕД База Данных запущена. В конфигурационном файле экспортёра в секции scrape_queries должно быть установлено значение "enabled": true.

    Запустите клиентскую часть РБДМонитор:

    systemctl start rdbmonitor-client.target