УРА!!!! У меня все получилось как и хотел!!!
Допилил найденный вчера скрипт под свои нужды, вроде четко работает.
Как итог:
- при пропадании питания от сети отправляется e-mail сообщение, смс сообщение через 3г модем, и в слог строка добавляется. Сообщение имеет текст содержащий "идентификатор микротика", дату и время отключения.
- при появлении питания от сети приходит аналогичное сообщение.
- при низком заряде батарей тоже шлет сообщение.
Используемое оборудование:
- Mikrotik PC v.5.24,
- ИБП фирмы APC подключенный к MikroTik через Usb2com (Usb со стороны ПК, Com-порт со стороны APC)
- 3G huawei e1550.
В итоге скрипт:
1) Делаем запуск скрипта через определенный промежуток (у меня 30 секунд.)
/system scheduler
add comment="" disabled=no interval=1m name="ups-powermonitor" on-event=ups-powermonitor \
start-date=jan/01/1970 start-time=00:00:00
2) Создаем новый скрипт с именем "ups-powermonitor"
В тексте скрипта вместо числа 1234567 вписываем свои значения.
===================================================================================
# UPS-Script powerfail
# © steinmann und weidinger OEG
#
www.stone-rich.at#
# Watches ups status and sends emails on power failure and low battery.
# This script will FAIL if:
# - Policies write, test, and read are not set
# - The system name contains non-standard characters (space, /, ...)
# - The UPS is not named ups1 (fixed by adding configurable variable)
#
# This script was tested up to ROS 3.23
# user-configurable parameters below:
:local mailserver "94.100.177.1";
:local mailfrom "1234567@mail.ru";
:local mailto "1234567@mail.ru";
:local user "1234567@mail.ru";
:local password "1234567";
:local upsName "ups1";
#
# do NOT make changes below!
#
:global flagonbatt;
:global flagbattlow;
:local battalarm 15;
:local battok 40;
:local curonbatt;
:local curcharge;
:local sysname [/system identity get name];
:local datetime "$[/system clock get date] $[/system clock get time]";
# First run? If so, we need to initialize the global flags
:if ([:typeof $flagonbatt]="nothing") do={:set flagonbatt 0}
:if ([:typeof $flagbattlow]="nothing") do={:set flagbattlow 0}
:set curonbatt false;
:set curcharge 100;
/system ups monitor [/system ups find name=$upsName] once do={
:set curonbatt $"on-battery";
:set curcharge $"battery-charge";
}
:if (($curonbatt) && ($flagonbatt=0)) do={
:set flagonbatt 1;
/tool e-mail send from=$mailfrom to=$mailto server=$mailserver user=$user password=$password subject="$sysname: Power failure!"
body="$sysname is on battery since $datetime";
:log info "Power-Fail: EMail sent to $mailto";
/tool sms send usb3 "+79281234567" message="$sysname: Power failure! Is on battery since $datetime";
}
:if ((!$curonbatt) && ($flagonbatt=1)) do={
:set flagonbatt 0;
/tool e-mail send from=$mailfrom to=$mailto server=$mailserver user=$user password=$password subject="$sysname: Power is back"
body="$sysname is back on power since $datetime";
:log info "Power-Restore: Email sent to $mailto";
/tool sms send usb3 "+79281234567" message="$sysname: Power is back! Is back on power since $datetime";
}
:if (($curcharge <= $battalarm) && ($flagbattlow=0)) do={
:set flagbattlow 1;
/tool e-mail send from=$mailfrom to=$mailto server=$mailserver user=$user password=$password subject="$sysname: Low battery!"
body="$sysname battery is at $curcharge %! $datetime";
:log info "Batt-Low: Email sent to $mailto";
/tool sms send usb3 "+79281234567" message="$sysname: Low battery!! Battery is at $curcharge %! $datetime";
}
:if (($curcharge >= $battok) && ($flagbattlow=1)) do={
:set flagbattlow 0;
/tool e-mail send from=$mailfrom to=$mailto server=$mailserver user=$user password=$password subject="$sysname: Battery
recharged" body="$sysname Battery recharged to $curcharge% $datetime";
:log info "Batt-Recharged: Email sent to $mailto";
/tool sms send usb3 "+79281234567" message="$sysname: Battery recharged! Battery recharged to $curcharge% $datetime";
}
===========================================================================================================================