Agent SNMP: различия между версиями
Matveevrj (обсуждение | вклад) |
|||
(не показано 14 промежуточных версий 3 участников) | |||
Строка 5: | Строка 5: | ||
Решение базируется на демоне snmpd, который разрабатывается и поддерживается открытым сообществом. Здесь даны общие рекомендации, подробную информацию ищите в [http://www.net-snmp.org/docs/man/snmpd.html официальной документации (англ)]. | Решение базируется на демоне snmpd, который разрабатывается и поддерживается открытым сообществом. Здесь даны общие рекомендации, подробную информацию ищите в [http://www.net-snmp.org/docs/man/snmpd.html официальной документации (англ)]. | ||
== Установка и предварительная настройка пакетов == | == Установка и предварительная настройка пакетов == | ||
Обновите источники и установите пакеты <code>snmp</code> и <code>snmpd</code>: | Обновите источники и установите пакеты <code>snmp</code> и <code>snmpd</code>: | ||
<syntaxhighlight lang="bash"> | <syntaxhighlight lang="bash"> | ||
apt update && apt - | apt update && apt-get install snmp snmpd -y | ||
</syntaxhighlight> | </syntaxhighlight> | ||
Строка 18: | Строка 17: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
В секцию <code># ACCESS CONTROL</code> допишите строчки: | |||
<syntaxhighlight lang="bash"> | |||
view systemonly included .1.3.6.1.4.1.2021.8 | view systemonly included .1.3.6.1.4.1.2021.8 | ||
view systemonly included .1.3.6.1.4.1.2021.9 | view systemonly included .1.3.6.1.4.1.2021.9 | ||
</syntaxhighlight> | </syntaxhighlight> | ||
А в конец файла допишите ссылки на скрипты: | |||
<syntaxhighlight lang="bash"> | |||
extend .1.3.6.1.4.1.2021.8 tt /var/lib/snmp/mqtt-snmp.sh | extend .1.3.6.1.4.1.2021.8 tt /var/lib/snmp/mqtt-snmp.sh | ||
pass .1.3.6.1.4.1.2021.9 /var/lib/snmp/mqtt-snmp_pass.sh | pass .1.3.6.1.4.1.2021.9 /var/lib/snmp/mqtt-snmp_pass.sh | ||
Строка 31: | Строка 32: | ||
== Добавление скрипта == | == Добавление скрипта == | ||
Отредактируйте скрипт <code>/var/lib/snmp/mqtt-snmp.sh</code> | Отредактируйте скрипт <code>/var/lib/snmp/mqtt-snmp.sh</code> | ||
<syntaxhighlight lang="bash"> | <syntaxhighlight lang="bash"> | ||
mcedit /var/lib/snmp/mqtt-snmp.sh | |||
</syntaxhighlight> | </syntaxhighlight> | ||
Строка 45: | Строка 42: | ||
#!/bin/sh | #!/bin/sh | ||
echo "mosquitto topics" | echo "mosquitto topics" | ||
# voltage Vout | |||
echo $(/usr/bin/mosquitto_sub -C 1 -t "/devices/wb-adc/controls/5Vout" 2>/dev/null) | |||
# voltage Vin | |||
echo $(/usr/bin/mosquitto_sub -C 1 -t "/devices/wb-adc/controls/Vin" 2>/dev/null) | |||
</syntaxhighlight> | </syntaxhighlight> | ||
OID'ы отдаваемые этим скриптом могут иметь тип только ''STRING'' | OID'ы отдаваемые этим скриптом могут иметь тип только ''STRING'' | ||
Строка 51: | Строка 51: | ||
Для демонстрации вывода других типов служит второй: | Для демонстрации вывода других типов служит второй: | ||
<syntaxhighlight lang="bash"> | <syntaxhighlight lang="bash"> | ||
mcedit /var/lib/snmp/mqtt-snmp_pass.sh | |||
</syntaxhighlight> | </syntaxhighlight> | ||
Содержимое: | Содержимое: | ||
Строка 65: | Строка 65: | ||
Установите права: | Установите права: | ||
<syntaxhighlight lang="bash"> | <syntaxhighlight lang="bash"> | ||
chmod a+rx /var/lib/snmp/mqtt-snmp.sh /var/lib/snmp/mqtt-snmp_pass.sh | chmod a+rx /var/lib/snmp/mqtt-snmp.sh | ||
chmod a+rx /var/lib/snmp/mqtt-snmp_pass.sh | |||
</syntaxhighlight> | </syntaxhighlight> | ||
Строка 77: | Строка 78: | ||
Можно протестировать: | Можно протестировать: | ||
<syntaxhighlight lang="bash"> | <syntaxhighlight lang="bash"> | ||
snmpwalk -On -c public | snmpwalk -On -v2c -c public 127.0.0.1 1.3.6.1.4.1.2021.8.4 | ||
snmpwalk -On -c public | </syntaxhighlight> | ||
и второй: | |||
<syntaxhighlight lang="bash"> | |||
snmpwalk -On -v2c -c public 127.0.0.1 1.3.6.1.4.1.2021.9 | |||
</syntaxhighlight> | </syntaxhighlight> | ||
Версия 16:49, 10 января 2023
Контроллер как источник SNMP
Иногда нужно получать какие-то параметры из контроллера по SNMP, например, значения топиков. Для реализации требуется установить и настроить на контроллере агента SNMP.
Решение базируется на демоне snmpd, который разрабатывается и поддерживается открытым сообществом. Здесь даны общие рекомендации, подробную информацию ищите в официальной документации (англ).
Установка и предварительная настройка пакетов
Обновите источники и установите пакеты snmp
и snmpd
:
apt update && apt-get install snmp snmpd -y
Отредактируйте основной файл конфигурации демона:
nano /etc/snmp/snmpd.conf
В секцию # ACCESS CONTROL
допишите строчки:
view systemonly included .1.3.6.1.4.1.2021.8
view systemonly included .1.3.6.1.4.1.2021.9
А в конец файла допишите ссылки на скрипты:
extend .1.3.6.1.4.1.2021.8 tt /var/lib/snmp/mqtt-snmp.sh
pass .1.3.6.1.4.1.2021.9 /var/lib/snmp/mqtt-snmp_pass.sh
Дополнительную информацио о параметрах конфигурационного файла можно в документации snmpd
Добавление скрипта
Отредактируйте скрипт /var/lib/snmp/mqtt-snmp.sh
mcedit /var/lib/snmp/mqtt-snmp.sh
И приведите его к виду:
#!/bin/sh
echo "mosquitto topics"
# voltage Vout
echo $(/usr/bin/mosquitto_sub -C 1 -t "/devices/wb-adc/controls/5Vout" 2>/dev/null)
# voltage Vin
echo $(/usr/bin/mosquitto_sub -C 1 -t "/devices/wb-adc/controls/Vin" 2>/dev/null)
OID'ы отдаваемые этим скриптом могут иметь тип только STRING
Для демонстрации вывода других типов служит второй:
mcedit /var/lib/snmp/mqtt-snmp_pass.sh
Содержимое:
#!/bin/sh -f
echo .1.3.6.1.4.1.2021.9.1
echo integer
/bin/systemctl is-active wb-mqtt-serial > /dev/null && echo 1 || echo 0
Скрипт возвращает INTEGER:1 если сервис wb-mqtt-serial запущен и 0 если нет.
Установите права:
chmod a+rx /var/lib/snmp/mqtt-snmp.sh
chmod a+rx /var/lib/snmp/mqtt-snmp_pass.sh
Теперь добавляем в этот скрипт нужные топики, или создаем несколько скриптов с разными наборами. Если вы создаете несколько скриптов, не забудьте дописать ссылки на них в конец файла /etc/snmp/snmpd.conf
.
После сохранения изменений в скрипте, перезапустите демон snmpd
:
systemctl restart snmpd && systemctl status snmpd
Можно протестировать:
snmpwalk -On -v2c -c public 127.0.0.1 1.3.6.1.4.1.2021.8.4
и второй:
snmpwalk -On -v2c -c public 127.0.0.1 1.3.6.1.4.1.2021.9