Skip to content

MXMP/swtoolz-core

 
 

Repository files navigation

SWToolz-Core - перерождение SWToolz, старого, доброго, лампового и теплого одновременно.

Предназначение сервиса

Сервис был разработан для облегчения управления сетевыми устройствами как в мультивендорной среде, так и в среде с разнообразным модельным рядом одного вендора. При работе с протоколом SNMP для получения определенных параметров приходится обращаться к идентификаторам этих параметров (или объектов) - OID. Очень часто одни и те же параметры для разных моделей устройств имеют уникальные OID, не совпадающие с аналогичными OID для других моделей. SWToolz-Core предоставляет единый интерфейс управления сетевым оборудованием, благодаря которому не приходится задумываться о таких мелочах. Любой метод, например set_AdminStatus, будет работать для любой модели любого вендора.

Это позволяет использовать swtoolz-core для интеграции с биллингом и системами отслеживания заявок, а также упрощает разработку собственного WEB-интерфейса для управления сетевым оборудованием.

Ниже приведен скриншот web-страницы проекта PortViewer, основанного на swtoolz-core:

PortViewer based on swtoolz-core

Возможности swtoolz-core

  • Автоопределение устройства и соответствующего файла конфигурации
  • Классификация моделей как по sysDescr, так и по sysName
  • Определение произвольного набора методов Get/Walk/Set для каждой модели устройства
  • Подстановка произвольного числа пользовательских параметров в любой OID
  • Одновременный вызов сразу нескольких методов
  • Упаковка нескольких запросов в один пакет

Особенности работы и отличия от swtoolz

  • Работа системным сервисом (daemon) под FreeBSD/Linux
  • Отсутствие привязки к конкретному оборудованию или вендору
  • Гибкая система конфигурирования
  • Изменение модулей не требует перезагрузки сервиса
  • Взаимодействие с сервисом осуществляется через API путем запроса соответствующего URL
  • Результат опроса возвращается в JSON

Требования

  • Операционная система FreeBSD или Linux
  • Python2 с модулем netsnmp. Может потребоваться установка python-pynetsnmp и python-netsnmp

Принцип работы

SWToolz-Core запускается системных сервисом и начинает опрашивать порт 7377 (по умолчанию). При подключении клиента и получении HTTP GET запроса, полученный URL разбирается на параметры. Минимальный набор параметров - имя пользователя, IP-адрес устройства, идентификатор SNMP-community, соответствующий пользователю, и вызываемый метод. К примеру, были получены такие параметры:

Параметр Описание
Имя пользователя default
IP-адрес 10.90.90.90
Индекс community 1
Метод walk_ifAlias

При этом произойдет следующее:

  • SWToolz-Core разберет запрос, посмотрит в основной файл конфигурации и извлечет SNMP-community с индексом 1 из набора возможных community для пользователя default.
  • После этого демон запустит отдельный поток в котором будет происходить вся дальнейшая работа:
    • Сервис запросит sysDescr и sysName (одним пакетом будут запрошены все параметры из default_info) у устройства с IP-адресом 10.90.90.90, обратившись к нему с полученным SNMP-community.
    • После получения ответа выполняется классификация устройства на основе параметров sysDescr и sysName и пользовательских настроек
    • Импортируется модуль (файл с настройками), соответствующий данному классу устройств
    • Из этого модуля выбирается объект walk_ifAlias
    • Объект интерпретируется и в него помещаются пользовательские параметры (если заданы)
    • Выполняется опрос устройства
    • Пользователю возвращается результат в JSON
  • Независимо от полученных результатов поток завершает свою работу

Конфигурирование сервиса

Описание параметров в файле swconfig.py

Параметр Описание
interface_ip IP-адрес интерфейса, на котором будет работать демон
port TCP-порт для прослушки (по умолчанию 7377).
sleep_int Пауза при опросе сокета в секундах (отсутствие паузы приведет к 100% загрузке CPU).
stats_int Интервал для статистики в файле журнала
set_iter_delay Пауза в секундах после set-операций
snmp_timeout Таймаут ожидания ответа для SNMP-запроса (в микросекундах)
snmp_retries Количество дополнительных попыток для SNMP-запроса. Значение '1' означает, что всего будет предпринято 2 попытки
no_retries Список методов, для которых значение snmp_retries будет всегда считаться равным нулю
forced_mtd Список методов, которые будут вызваны даже если устройство недоступно
logfile Файл журнала
users Пользователи и их наборы snmp-community
default_info Имена и OID'ы параметров, запрашиваемых у устройства в обязательном порядке
models_by_desc Соответствие описаний моделей их названиям. Список проверяется до первого соответствия
http_header Шаблон HTTP-заголовка для ответа клиенту
debug_mode Режим отладки. Если включен, то в лог-файл будет отправляться дополнительная информация

Описание параметра 'users'

Параметр users представлен в виде словаря Python. Значение каждого элемента этого словаря, в свою очередь, тоже является словарем. В нем хранится соответствие SNMP-community определенному индексу.

users = {
    'default'  : {'1' : 'public', '2' : 'private'},
    'test'     : {'6' : 'my_read', '7' : 'my_write'},
    }

Благодаря users значение SNMP-community не передается открытым текстом в запросах.

Описание параметра 'default_info'

Параметр default_info представлен в виде словаря Python, в котором ключ содержит имя параметра, а значение - соответствующий ему OID.

default_info = {
    'sys_descr'    : '.1.3.6.1.2.1.1.1.0',
    'sys_uptime'   : '.1.3.6.1.2.1.1.3.0',
    'sys_name'     : '.1.3.6.1.2.1.1.5.0',
    'sys_location' : '.1.3.6.1.2.1.1.6.0',
    }

Все эти параметры будут запрошены у устройства при первом обращении. Параметры sys_name и sys_descr зарезервированы и используются для определения модели устройства

Описание параметра 'models_by_desc'

Параметр models_by_desc представлен в виде списка словарей. Ключом словаря является подстрока, входящая в строки в sysDescr или sysName. Значением словаря является локально значимое имя модели и соответствующего ей файла в директории ./devices.

Пример:

models_by_desc = [
    {'DES-3200-28/C1' : 'DES-3200-28_C1'},
    {'DES-3200-28'    : 'DES-3200-28'},
    {'DES-3200-18/C1' : 'DES-3200-18_C1'},
    {'DES-3200-18'    : 'DES-3200-18'},
    {'DES-3200-10'    : 'DES-3200-10'},
    {'DES-3028G'      : 'DES-3028G'},
    {'DES-3028'       : 'DES-3028'},
    {'DES-3026'       : 'DES-3026'},
    {'DGS-3100-24TG'  : 'DGS-3100-24TG'},
    {'DGS-3120-24SC/B': 'DGS-3120-24SC_B'},
    {'DGS-3120-24SC'  : 'DGS-3120-24SC'},
    {'DGS-3000-28SC'  : 'DGS-3000-28SC'},
    {'DGS-3000-24TC'  : 'DGS-3000-24TC'},
    {'DGS-3612G'      : 'DGS-3612G'},
    {'DGS-3627G'      : 'DGS-3627G'},
    {'BigIron 8000'   : 'Foundry'},
    {'BigIron 4000'   : 'Foundry'},
    {'FastIron 800'   : 'Foundry'},
    {'FastIron 400'   : 'Foundry'},
    {'FastIron SX 800': 'Foundry'},
    {'NetIron 800'    : 'Foundry'},
    {'IronWare'       : 'Foundry'},
    {'TurboIron-X24'  : 'Foundry'},
    {'BigIron RX'     : 'BigIron-RX'},
    {'c2950-MGMT'     : 'WS-C2950G-48-EI'},
    {'cat3550-12G'    : 'WS-C3550-12G'},
    {'Cat3550-12G'    : 'WS-C3550-12G'},
    {'Core7k-17'      : 'WS-C3550-12G'},
    {'Kalach_cat3550' : 'WS-C3550-12G'},
    {'Bereslavka-Cat' : 'WS-C3550-12G'},
    {'CiscoWisi'      : 'WS-C3560X-24'},
    {'AdmRack-c3750'  : 'WS-C3750-24PS-S'},
    {'Cat3750-48_TV'  : 'WS-C3750-48TS-S'},
    {'GGC-3750G-16TD' : 'WS-C3750G-16TD'},
    {'SCE8000'        : 'SCE8000'},
    {'Redback'        : 'Redback'},
    {'MES2124'        : 'MES-2124'},
    {'MES3124F'       : 'MES-3124F'},
    {'APC Web/SNMP'   : 'APC-Smart-UPS'},
    ]

Данный список проверяется до первого соответствия. Если ключ входит в значение sysName или sysDescr, то проверка прекращается и названием модели считается значение ключа словаря. К примеру, если было найдено вхождение FastIron SX 800 в параметр sysName или sysDescr, то названием модели будет Foundry и при обращении к устройству будет импортирован модуль с именем Foundry.

Если название модели определить не удалось и при этом используется режим FORCED (см. список параметров), то будет импортирован модуль None. Соответственно, все методы, которые предполагается использовать при недоступном устройстве, следует описывать в модуле None.

Конфигурирование модулей

Модули хранятся в директории ./devices. Каждый модуль содержит описания методов, которые могут быть вызваны для данного устройства. Метод с точки зрения Python является объектом и может быть представлен в виде кортежа, словаря или списка. Тип объекта указывает swtoolz-core на то, как надо интерпретировать объект.

Кортежи (неизменяемые объекты)

Пример объекта, являющегося кортежем:

# swL2PortInfoMediumType
MediumType = ({
    '1' : 'copper',
    '2' : 'fiber',
    },)

Когда swtoolz-core обнаруживает такой объект, он возвращает его 'как есть'. Это удобно использовать для получения расшифровки параметров в виде JSON. В данном случае смысл здесь примерно такой же, как и в подключении MIB - если при помощи одного метода мы получаем численные значения параметров, то сразу после этого (или одновременно) мы можем сразу же получить и расшифровку этих параметров.

Это решает одну серьезную проблему, которая может возникнуть при использовании MIB. К примеру, мы получили значение актуальной скорости порта коммутатора, которое говорит о том, что линк поднят в режиме 100 мегабит/фуллдуплекс. При этом в различных MIB для различных моделей это значение может расшифровываться как '100M-Full', так и '100M Full' или '100 Mb Full' или '100M fullduplex' и т.д. Человеку понятно, а программе не очень. Используя кортежи можно легко привести все к "одному знаменателю", получая расшифровку параметра в удобном для своих сервисов виде.

ВНИМАНИЕ! Чтобы объект считался кортежем, он должен содержать запятую!

Словари (наборы для snmpwalk- и snmpget-операций)

Пример объекта, являющегося словарем (snmpwalk):

walk_AllPorts = {
#    MediumType          .1.3.6.1.4.1.171.11.113.5.1.2.3.1.1.2          swL2PortInfoMediumType
    'MediumType'      : '.1.3.6.1.4.1.171.11.113.5.1.2.3.1.1.2',
#    ActualStatus        .1.3.6.1.4.1.171.11.113.5.1.2.3.1.1.5          swL2PortInfoLinkStatus
    'ActualStatus'    : '.1.3.6.1.4.1.171.11.113.5.1.2.3.1.1.5',
#    ActualSpeed         .1.3.6.1.4.1.171.11.113.5.1.2.3.1.1.6          swL2PortInfoNwayStatus
    'ActualSpeed'     : '.1.3.6.1.4.1.171.11.113.5.1.2.3.1.1.6',
#    AdminStatus         .1.3.6.1.4.1.171.11.113.5.1.2.3.2.1.4          swL2PortCtrlAdminState
    'AdminStatus'     : '.1.3.6.1.4.1.171.11.113.5.1.2.3.2.1.4',
#    AdminSpeed          .1.3.6.1.4.1.171.11.113.5.1.2.3.2.1.5          swL2PortCtrlNwayState
    'AdminSpeed'      : '.1.3.6.1.4.1.171.11.113.5.1.2.3.2.1.5',
#    AdminFlow           .1.3.6.1.4.1.171.11.113.5.1.2.3.2.1.6          swL2PortCtrlFlowCtrlState
    'AdminFlow'       : '.1.3.6.1.4.1.171.11.113.5.1.2.3.2.1.6',
    }

Когда swtoolz-core обнаруживает такой объект, он интерпретирует его как набор метрик, для которых надо выполнить операции snmpwalk или snmpget. По умолчанию типом операции считается snmpwalk, но если хотя бы в одном имени метрики присутствует точка, то для всех OID в словаре будет выполнена операция snmpget.

Пример объекта, являющегося словарем (snmpget):

get_PortIndex = {
#    PortIndex           .1.3.6.1.4.1.171.11.113.5.1.2.3.1.1.1          swL2PortInfoPortIndex
    'PortIndex..1'    : '.1.3.6.1.4.1.171.11.113.5.1.2.3.1.1.1.1.1',
    'PortIndex..2'    : '.1.3.6.1.4.1.171.11.113.5.1.2.3.1.1.1.2.1',
....
....
    'PortIndex..24'   : '.1.3.6.1.4.1.171.11.113.5.1.2.3.1.1.1.24.1',
    'PortIndex..25c'  : '.1.3.6.1.4.1.171.11.113.5.1.2.3.1.1.1.25.1',
    'PortIndex..25f'  : '.1.3.6.1.4.1.171.11.113.5.1.2.3.1.1.1.25.2',
    'PortIndex..26c'  : '.1.3.6.1.4.1.171.11.113.5.1.2.3.1.1.1.26.1',
    'PortIndex..26f'  : '.1.3.6.1.4.1.171.11.113.5.1.2.3.1.1.1.26.2',
    'PortIndex..27'   : '.1.3.6.1.4.1.171.11.113.5.1.2.3.1.1.1.27.2',
    'PortIndex..28'   : '.1.3.6.1.4.1.171.11.113.5.1.2.3.1.1.1.28.2',
    }


Тип операции оказывает влияние на имя метрики, возвращаемой в ответе клиенту. В случае snmpwalk имя метрики будет получено по следующей формуле:

имя_метрики = результат - значение_ключа

Например, для параметра ActualStatus оно будет вычислено так:

.1.3.6.1.4.1.171.11.113.5.1.2.3.1.1.5.25.1 - .1.3.6.1.4.1.171.11.113.5.1.2.3.1.1.5 = 25.1

В случае snmpget имя метрики будет получено по формуле:

имя_метрики = последние № чисел из результата (где № - количество точек в имени ключа)

Например, для параметра PortIndex имена ключей из примера выше будут такими:

'1.1',
'2.1',
....
....
'24.1',
'25.1',
'25.2',
'26.1',
'26.2',
'27.2',
'28.2',

Поскольку в имени ключа содержатся две точки (PortIndex..1), то из результирующего OID используются 2 последних числа.

Значения после первой точки игнорируются. То есть нет разницы задавать ли имена 'PortIndex..26c' и 'PortIndex..26f' или же 'PortIndex..abcd' и 'PortIndex..dcba' - все равно ключи метрик будут, в данном случае, '26.1' и '26.2'.

Само же имя метрики из словаря в ответе будет являться ключом словаря результатов. Ниже приведен пример вызова метода get_SinglePort с параметром 25:

"data": {
    "AdminStatus": {
	"25.100": "3",
	"25.101": "3"
    },
    "ActualStatus": {
	"25.100": "2",
	"25.101": "3"
    },
    "ActualSpeed": {
	"25.100": "7",
	"25.101": "1"
    },
    "MediumType": {
	"25.100": "100",
	"25.101": "101"
	},
    "AdminFlow": {
	"25.100": "2",
	"25.101": "2"
    },
    "PortType": {
	"25": "2"
    },
    "AdminSpeed": {
	"25.100": "1",
	"25.101": "1"
    },
    "PortDescr": {
	"25": "Uplink"
    }
}

В общем и целом работа с именами метрик идентична поведению Briseis.

Helpers (пользовательские функции)

Для словарей возможно применение пользовательских функций, которые каким-либо образом обрабатывают ответ от устройства и возвращают измененные значения. Сами функции должны находиться в файле helpers.py. Для того, что бы функция сработала нужно в словаре добавить элемент helper, значением которого является имя функции для вызова.

Пример получения диагностики кабеля на коммутаторах SNR-S2985G-24T:

get_CableDiag = {
    # helper function converts VCT results to D-Link format
    'helper': 'snr_diag_parser',
    # ActualStatus    .1.3.6.1.2.1.2.2.1.8  ifOperStatus
    'ActualStatus.': '.1.3.6.1.2.1.2.2.1.8.%s',
    # cableDiag    .1.3.6.1.4.1.40418.7.100.3.2.1.19  vctLastStatus
    'cableDiag.': '.1.3.6.1.4.1.40418.7.100.3.2.1.19.%s'
}

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

Списки (наборы для snmpset-операций)

Пример объекта, являющегося списком:

set_AdminStatus = [
#     .1.3.6.1.4.1.171.11.113.5.1.2.3.2.1.4                             swL2PortCtrlAdminState
    ['.1.3.6.1.4.1.171.11.113.5.1.2.3.2.1.4.%s', '1', '%s', 'INTEGER'],
    ]

Каждый элемент такого списка, в свою очередь, также является списком, содержащим 4 обязательных параметра: tag, iid, val и type. Когда swtoolz-core обнаруживает такой объект, он интерпретирует его как набор параметров, которые следует использовать в операции snmpset. Ниже приведено описание параметров вложенного списка в том виде, в каком оно дано в документации к netsnmp для Python.

Параметр Описание
tag fully qualified, dotted-decimal, numeric OID
iid the dotted-decimal, instance identifier
val the SNMP data value
type SNMP data type

Пример: ['.1.3.6.1.2.1.17.7.1.4.3.1.2','777','\x00\x00\x00\xf0\x00\x00\x00\x00','OCTETSTR']
Эквивалентная команда: snmpset -v2c -c <WComm> <IP> .1.3.6.1.2.1.17.7.1.4.3.1.2.777 x 000000f000000000

Результат команды snmpset будет либо 1 (успех) либо 0 (неудача). Пример:

"data":	{
    "set_AdminStatus": 1
    }

Пояснения к работе swtoolz-core

Использование сервиса

Для вызова необходимого метода достаточно обратиться к соответствующему URL. Пример:

http://my.host:7377/default/10.90.90.905/1/walk_ifAlias

Чтобы передать сервису определенный параметр, нужно указать его после имени метода через символ '/':

http://my.host:7377/default/10.90.90.905/1/get_SinglePort/25

Можно вызывать несколько методов одновременно, разделяя их знаком '+':

http://my.host:7377/default/10.90.90.905/1/get_SinglePort/25+/get_SinglePort/26

Можно одновременно вызывать несколько методов с разными типами и разным количеством параметров:

http://my.host:7377/default/10.90.90.90/2/get_SinglePort/25+/walk_ifAlias+/set_AdminStatus/1/2

ВНИМАНИЕ! Перед названием каждого метода и перед каждым параметром должен стоять знак '/'!

Использование пользовательских параметров при опросе устройств

SWToolz-Core позволяет использовать внутри OID параметры, передаваемые в URL. В случае, если ожидается подстановка параметра, следует использовать зарезервированные символы '%s' или '{№}'. Значения параметров можно подставлять не только в OID (tag), но также в iid и в val. Выше, в описании метода 'set_AdminStatus', приведен пример использования '%s'. Параметры указываются в URL после имени метода и затем последовательно подставляются вместо символов '%s'. Таким образом, в случае вызова метода 'set_AdminStatus' с параметрами 1 и 2, результатом будет:

['.1.3.6.1.4.1.171.11.113.5.1.2.3.2.1.4.1', '1', '2', 'INTEGER'],

Напомню, что изначально объект был описан так:

['.1.3.6.1.4.1.171.11.113.5.1.2.3.2.1.4.%s', '1', '%s', 'INTEGER'],

Параметры можно подставлять не только последовательно, но и обращаясь к ним по их порядковым номерам. Для этого используется конструкция '{№}', где - порядковый номер параметра. Этот прием можно использовать, когда требуется подставить параметры в несколько строк, либо когда один параметр нужно использовать несколько раз. Ниже приведен пример метода 'set_CreateVlan', в который передаются три параметра. При этом параметры подставляются в разные элементы списка (в iid и в val), а первый из них используется три раза.

set_CreateVlan = [
#     .1.3.6.1.2.1.17.7.1.4.3.1.1                                       dot1qVlanStaticName
    ['.1.3.6.1.2.1.17.7.1.4.3.1.1', '{1}', '{2}', 'OCTETSTR'],
#     .1.3.6.1.2.1.17.7.1.4.3.1.2                                       dot1qVlanStaticEgressPorts
    ['.1.3.6.1.2.1.17.7.1.4.3.1.2', '{1}', '{3}', 'OCTETSTR'],
#     .1.3.6.1.2.1.17.7.1.4.3.1.5                                       dot1qVlanStaticRowStatus
    ['.1.3.6.1.2.1.17.7.1.4.3.1.5', '{1}', '4', 'INTEGER'],
    ]

При всем этом, конструкции '%s' или '{№}' можно использовать вместе.

При работе с протоколом SNMP в некоторых случаях не обойтись без использования шестнадцатеричных кодов. Так, например, для указания StaticEgressPorts нужно отправить последовательность байт, где нужные биты, соответствующие портам, установлены в 1. Для портов 25-28 эта последовательность будет '0x000000f000000000'. Чтобы передать такие символы в SWToolz-Core, следует использовать percent‐encoding. Иными словами, в URL данная последовательность будет выглядеть так - '%00%00%00%f0%00%00%00%00'.

Обратная связь с пользователем

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

"request": {
    "errors": [0],
    "comm_index": "2",
    "data": [{
	"0": "set_AdminStatus",
	"1": "1",
	"2": "2"
    }],
    "user": "default",
    "target": "10.90.90.90"
}

Параметр 'errors' содержит код возможных ошибок. Ниже приведена расшифровка кодов:

Параметр Описание
0 OK
1 Missing mandatory parameters: /user, /target, /comm_index
2 User is not found
3 Snmp-community is not defined for this index
4 IP-address is not correct

Таким образом, код 0 сообщает о том, что ошибок в запросе не обнаружено.

Одновременный запрос нескольких параметров

Все параметры, находящиеся внутри одного объекта (кортежа, словаря или списка) опрашиваются одновременно. Для snmpget и snmpset запросов это означает, что для каждого объекта будет отправлен всего один пакет. Ответ при этом тоже поступит в одном пакете. Так, например, метрики PortIndex (из примера выше) при вызове метода get_PortIndex будут получены одновременно.

Если же используется snmpwalk, то запросы также выполняются одновременно, а их число соответствует длине самой короткой ветви с OID. Например, при вызове метода walk_AllPorts одновременно придут результаты 'MediumType', 'ActualStatus', 'ActualSpeed', 'AdminStatus', 'AdminSpeed' и 'AdminFlow' для порта №1. В следующем пакете - для порта №2 и так далее. Когда одна из веток закончится, опрос будет прекращен. Поэтому, чтобы были получены все необходимые параметры, ветки должны быть одинаковой длины. Иными словами, нельзя одним методом получить и список описаний портов и список MAC-адресов, так как длина этих списков различна. А вот свойства порта, находящиеся в одном разделе MIB, будут иметь одинаковую длину, поэтому есть смысл опрашивать их вместе.

Данная методика увеличивает скорость и надежность получения данных.

Опрос недоступного оборудования и неправильные запросы

Опрос устройства выполняется только в том случае, если пришел ответ на первый запрос (где запрашиваются параметры из default_info). Если ответ получен не был, то опрос считается завершенным, а пользователь получит ответ, где поле 'data' в ответе будет пустым.

Тем не менее, существует возможность отправить команду недоступному устройству. Для этого существует режим FORCED, который включается автоматически, если используемый метод перечислен в зарезервированном списке forced_mtd (см. список параметров). Если устройство недоступно, то его модель будет определена как None, поэтому методы, которые можно вызвать для такого устройства, должны быть описаны в модуле None. Результат операции, разумеется, останется неизвестным, но пакет при этом будет отправлен устройству.

Метод FORCED может пригодиться в случае, когда заведомо известно, что устройство работает и подключено в сеть, но обратные пакеты от него не могут достигнуть управляющей станции. Причины могут быть разными: проблемы маршрутизации, ошибки в ACL, отсутствие нужного маршрута или шлюза по умолчанию и т.д. К примеру, при помощи метода 'set_IpifCfg' в режиме FORCED можно изменить IP-адрес коммутатора D-Link с IP-адресом по умолчанию 10.90.90.90. Если в VLAN с коммутатором добавить интерфейс из этой сети, например 10.90.90.89/30, и проанонсировать сеть в OSPF, то пакет от SWToolz-Core достигнет устройства и вынудит его перенастроить свой системный интерфейс.

SWToolz-Core работает только с теми запросами, которые он смог интерпретировать. Если же сервис не распознал запрос пользователя, то поле 'data' в ответе будет пустым. При этом, если само устройство доступно, то опрошенные параметры из default_info будут содержаться в ответе.

При ошибках импортирования модулей или при вызове несуществующих параметров информация об этом попадает в лог сервиса.

Установка под FreeBSD

  • Скопируйте файл swtoolz-core из директории 'freebsd' в '/usr/local/etc/rc.d/', а остальные файлы в '/usr/local/etc/swtoolz-core/'.
  • Добавьте строку swtoolz_core_enable="YES" в файл '/etc/rc.conf'.
  • Убедитесь, что firewall разрешает SNMP-запросы.
  • Запустите сервис командой service swtoolz-core start.

Установка под Linux

  • Скопируйте файл swtoolz-core из директории 'linux' в '/etc/init.d/', а остальные файлы в '/usr/local/etc/swtoolz-core/'.
  • Убедитесь, что firewall разрешает SNMP-запросы.
  • Запустите сервис командой service swtoolz-core start.

Пример скрипта для получения результатов диагностики кабеля

В моей компании чаще всего пишут на PHP, поэтому пример будет на этом языке. Сильно не пинайте, PHP я не помнил и давно забыл.

Сначала нам нужна функция, которая будет отсылать запросы на сервис:

/**
 * Посылает запрос к SWToolz-Core и возвращает результат в виде JSON без каких-либо преобразований.
 *
 * @param $command string Команда, которую нужно послать сервису.
 * @return array Ответ от сервиса в виде JSON.
 */
function swtoolz_send_command(string $command)
{
    $cURL = curl_init("http://swtoolz-url.com/user/$command");
    curl_setopt($cURL, CURLOPT_PORT, 7377);
    curl_setopt($cURL, CURLOPT_RETURNTRANSFER, true);
    $url = curl_exec($cURL);
    return json_decode($url, true);
}

Устанавливаем начальные параметры работы скрипта:

$deviceip = '10.90.90.90'; // ip-адрес коммутатора
$communityId = 3; // id строки community в сервисе SWToolz-Core для обращения к оборудованию
$portnum = 3; // номер порта

Выполняем запросы к сервису и отрисовываем результаты:

// Получаем с сервиса расшифровки числовых статусов и запускаем процесс диагностики порта
$statuses = swtoolz_send_command("$deviceip/$communityId/cdPairStatus+/cdLinkStatus+/set_CableDiagInit/$portnum")['response']['data'];
// Получаем с сервиса реузультаты диагностики
$diagResults = swtoolz_send_command("$deviceip/$communityId/get_CableDiag/$portnum")['response']['data'];

$linkStatus = $diagResults['cdLinkStatus'][$portnum]; // статус линка в числовом формате
$humanLinkStatus = $statuses['cdLinkStatus'][$linkStatus]; // статус линка в человекочитаемом формате
print("Статус линка: $humanLinkStatus" . PHP_EOL);

// Как мы знаем, в кабеле 4 пары, "дергаем" параметры для каждой из них
for ($pairNum = 1; $pairNum <= 4; $pairNum++) {
    $pairLength = $diagResults["cdPair{$pairNum}Length"][$portnum]; // длина пары
    $pairStatus = $diagResults["cdPair{$pairNum}Status"][$portnum]; // статус пары в числовом формате
    $humanPairStatus = $statuses['cdPairStatus'][$pairStatus]; // статус пары в человекочитаемом формате
    print("Пара $pairNum: длина - $pairLength, статус - $humanPairStatus" . PHP_EOL);
}

Список изменений

[1.7.20] - 2016.07.20

Добавлено

  • В некоторые модули D-Link добавлены методы загрузки и выгрузки конфигурации

Исправлено

  • Исправлено имя переменной, содержащей IP-адрес интерфейса

[1.6.27] - 2016.06.27

Добавлено

  • Добавлены новые модули оборудования и усовершенствованы старые

Удалено

  • Поле 'user' удалено из ответа сервиса (ключ 'response')

[1.5.2] - 2016.05.14

Добавлено

  • Пользовательские параметры можно подставлять не только последовательно, но и по их номерам
  • Список методов ('forced_mtd'), которые будут вызваны даже если устройство недоступно
  • Несколько новых модулей оборудования

Исправлено

  • Исправлена ошибка определения модели устройства. Теперь определение модели 'до первого соответствия' работает корректно

Изменено

  • Для устройств D-Link добавлены новые методы ('set_CreateVlan', 'set_IpifCfg', 'set_DHCP_RemoteID')
  • Изменена документация в соответствии со сделанными исправлениями

[1.0.0] - 2016.03.18

Релиз версии 1.0.0

About

SNMP-to-JSON API for network equipment polling

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Python 99.6%
  • Other 0.4%