|
test-org/integration-module/pipeline/pr-rc This commit looks good
Details
|
||
|---|---|---|
| crates | ||
| .dockerignore | ||
| .env.example | ||
| .gitignore | ||
| Cargo.toml | ||
| Dockerfile | ||
| Jenkinsfile | ||
| README.md | ||
| config_api.json | ||
| template_global_config.json | ||
README.md
Интеграционный модуль для проекта "Буревестник ВКС"
Описание
Интеграционный модуль (ИМ) - Rust-пакет, предоставляющий функционал интеграционного модуля в проекте "Буревестник ВКС", состоящий из бинарных крейтов для:
- получение данных через API ВКС
- поддержку хранения, валидации и актуализации собственных конфигураций
- предобработку полученных данных и сохранение в БД
- интеграции с
еНОД.Мониторинг
Специфика работы
На даннный момент предусмотрено два режима работы:
-
Нативный - режим работы, производящий прямой опрос сервиса видео-конференц связи
Vinteoи соотвествующий процессETL -
Статичный - режим работы "посредник", когда все метрические данные ВКС
Vinteoполучаются черезREST-Full APIсредстваеНОД.Мониторинг -
Системный - аналогичный статичному режиму, но метрические данные (заведомо обогащенные нулевым статусом) отправялются не напрямую в модуль
Prometehus exporter, а вСтатусную модель -
Vinteo - особый режим работы, предполагающий сбор определенного набора метрик напрямую с ВКС
Vinteoмеханизмом многоэтапногоAPI-запроса
Примечание По стандарту
ИМработает в НАТИВНОМ режиме и ожидает конфигурации в формате.json, однако приоритетным считается СТАТИЧНЫЙ режим. Подробная информация о настройке в пунктеРуководство
Руководство
В данном разделе опсиан алгоритм настройки, сборки и запуска программного модуля ИМ
Преднастройка
- Выбор режима работы модуля, который скорректирует принцип настройки:
| Режим работы | .env | config-api.json | $STATUS_SYSTEM_URL | $EXPORTER_URL |
|---|---|---|---|---|
| Нативный | ❌ | ✅ | ❌ | ❌ |
| Статичный | ✅ | ❌ | ❌❌❌ | ✅ |
| Системный | ✅ | ❌ | ✅ | ❌ |
| , где: |
✅ -- следует настроить (предпринять)
❌ -- игнорируется системой, не стоит настраивать
❌❌❌ -- НЕЛЬЗЯ настраивать (предпринимать), возможны ошибки в работе
Режим работы
Vinteoне описан в таблице намеренно
Настройка режима работы "Нативный"
Для настройки данного режима необходимо расположить в активной директории конфигурационный config_api.json файл:
{
"config": [
{
"id":"zvks",
"login" : "",
"pass" : "",
"api_key" : "6fe8b0db-62b4-4065-9c1e-441ec4228341.9acec20bd17d7178f332896f8c006452877a22b8627d089105ed39c5baef9711",
"period" : "",
"timeout" : "5",
"metrics" : [
{
"name": "conferences",
"url": "https://demo.vcs.vinteo.dev/api/v1/conferences",
"measure": [
{ "id":"number", "type": "text", "addr": "data.conferences[].number" },
{ "id":"total", "type": "integer", "addr": "data.total" },
{ "id":"participants_total", "type": "integer", "addr": "data.conferences[].participants.total" },
{ "id":"parts_total_in_each", "type": "integer", "addr": "data.conferences[description].participants.total" },
{ "id":"participants_online", "type": "integer", "addr": "data.conferences[].participants.online" }
]
},
{
"name": "abonents",
"url": "https://demo.vcs.vinteo.dev/api/v1/accounts",
"measure": [
{ "id":"total", "type": "integer", "addr": "data.total" }
]
}
]
}
]
}
Примечание Название конфигурационного файла должно быть как в примере -
config_api.json
Настройка режима работы "Статичный"
Для настройки данного режима необходимо пополнить данными о сервере в .env файле по примеру:
...
EXPORTER_URL = "http(s)://ip.ip.ip.ip:port" # <--- экспорт данных (обязательно)
# eNODE.Monitoring configuration
ENODE_MONITORING_IP = "ip.ip.ip.ip"
# admin user is required
ENODE_MONITORING_LOGIN = "admin_user_enode_monitoring"# ---> получение данных
# admin password is required
ENODE_MONITORING_PASSWORD = "admin_password_enode_monitoring"
...
Настройка режима работы "Системный"
Для настройки данного режима необходимо пополнить данными о сервере в .env файле по примеру:
...
STATUS_SYSTEM_URL = "http(s)://{ip}:{port}/api/input"# <--- экспорт данных
# eNODE.Monitoring configuration
ENODE_MONITORING_IP = "{ip}.{ip}.{ip}.{ip}"
# admin user is required
ENODE_MONITORING_LOGIN = "admin_user_enode_monitoring"# ---> получение данных
# admin password is required
ENODE_MONITORING_PASSWORD = "admin_password_enode_monitoring"
...
Настройка режима работы "Vinteo"
Для работы в данном режиме необходимо установить переменные окружения в соотвествии со списком ниже
...
VINTEO_URL_BASE = "https://demo.vcs.vinteo.dev"
VINTEO_ENDPOINT_CONFERENCES = "/api/v1/conferences"
VINTEO_ENDPOINT_PARTICIPANTS = "/api/v1/participants/"
VINTEO_API_KEY = "00000000000111111111.aaaaaaaaaaaaaaabbbbbbbbbbbbb"
...
Настройка экспорта полученных и обработанных данных
Настройка точки выхода для полученных и обработанных метрик определеяется установленными в переменных окружения параметрами, варианта два:
- Экспорт в статусную модель в рамках механизма сквозного прохода данных в проекте
Буревестник ВКС
...
STATUS_SYSTEM_URL = "{BASE_URL}/{ROUTE}"
...
- Экспорт в экспортер или иной потребитель данных
...
EXPORTER_URL = "{BASE_URL}/{ROUTE}"
...
ОЧЕНЬ ВАЖНОЕ ПРИМЕЧАНИЕ
Одновременное использование
$STATUS_SYSTEM_URLи$EXPORTER_URLНЕДОПУСТИМО !! Вариант со ссылкой на статусную модель является по стандарту БОЛЕЕ ПРИОРИТЕТНЫМ, второй затрется, использовать необходимо только один
- Произвести сборку проекта командой :
cargo build --release
- Запустить
Debug версия
cargo run --bin api-grub
или
Release версия
cargo run --release --bin api-grub
Текущий прогресс
| Крейт (подмодуль) | Прогресс |
|---|---|
api-grub |
✅✅✅✅✅✅✅✅✅🛠️ |
config-delivery [migrated] |
❌❌❌❌❌❌❌❌❌❌ |
integrs-structs |
✅✅✅✅✅✅✅✅✅✅ |
preproc [temp-deprecated] |
❌❌❌❌❌❌❌❌❌❌ |