|
test-org/integration-module/pipeline/pr-master There was a failure building this commit
Details
Reviewed-on: http://git.enode/deployer3000/integration-module/pulls/49 |
||
|---|---|---|
| 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получаются черезFull REST APIсредстваеНОД.Мониторинг -
Системный - аналогичный статичному режиму, но метричекие данные (заведомо обогащенные нулевым статусом) отправялются не напрямую в модуль
Prometehus exporter, а вСтатусную модель
Примечание По стандарту
ИМработает в НАТИВНОМ режиме и ожидает конфигурации в формате.json, однако приоритетным считается СТАТИЧНЫЙ режим. Подробная информация о настройке в пунктеРуководство
Руководство
В данном разделе опсиан алгоритм настройки, сборки и запуска программного модуля ИМ
Преднастройка
- Выбор режима работы модуля, который скорректирует принцип настройки:
| Режим работы | .env | config-api.json | $STATUS_SYSTEM_URL | $EXPORTER_URL |
|---|---|---|---|---|
| Нативный | ❌ | ✅ | ❌ | ❌ |
| Статичный | ✅ | ❌ | ❌❌❌ | ✅ |
| Системный | ✅ | ❌ | ✅ | ❌ |
| , где: |
✅ -- следует настроить (предпринять)
❌ -- игнорируется системой, не стоит настраивать
❌❌❌ -- НЕЛЬЗЯ настраивать (предпринимать), возможны ошибки в работе
Настройка режима работы "Нативный"
Для настройки данного режима необходимо расположить в активной директории конфигурационный 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"
...
- Произвести сборку проекта командой :
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] |
❌❌❌❌❌❌❌❌❌❌ |