Я думаю многим опытным пользователям ПК, особенно IT-специалистам, хочется контролировать всё и вся. В эту категорию входит и мониторинг домашнего интернета и подключенных к нему устройств, особенно в ваше отсутствие. Многие, кто работают за ПК, часто используют удаленное подключение к домашнему ПК, чтобы заниматься попутно какими либо своими делами. Для этого было бы неплохо точно знать когда и что происходило с интернет-соединением. Если у вас есть Микротик, обязательно закажите внешний IP и тогда вы по-настоящему сможете все держать под контролем. В этой статье речь пойдет о мониторинге доступности подключенного к Микротику ПК с грамотным логированием.
Представляю вашему вниманию скрипт для Микротика на базе RouterOS, который ставится на запуск каждую минуту и выполняет следующий функционал:
- Мониторинг доступности запущенного ПК
- Логирование недоступности ПК, отсутствия линка до ПК
- Скрипт различает недоступность ПК от выключенного ПК и не засоряет логи
В логах MikroTik используется 3 цвета
- серый — info-сообщения
- синий — warning-сообщения
- красный — error-сообщения
В скрипте я использую warning и error логирование, чтобы открыв лог вы наглядно могли выцепить из него только нужные вам сообщения.
Для хранения информации (пропал пинг ПК, пропал линк к ПК) используются глобальные переменные (раздел System->Scripts вкладка Environment). Если у вас пропал интернет, например авария у провайдера), в логе будет только одно сообщение об этом и скрипт не будет писать в лог об отсутствии пинга каждый свой запуск (каждую минуту).
Давайте рассмотрим скрипт по частям:
:global linkdown:global landown :local checklan [/ping 10.10.1.10 count=5] :local link/interface ethernet cable-test eth2-lan once do={:set $link $"status";};
Это первая часть кода, здесь объявляются переменные, выполняется пинг локального ip подключенного ПК и проверка линка на нужном порту (тест кабеля). IP вам нужно заменить на IP вашего ПК, а название порта к которому подключен ПК тоже заменить на свое (раздел Interfaces).
:if ($link = "link-ok") do={ :if ($linkdown = true) do={ /log warning "LAN LINK UP" :set $linkdown false }
Если линк есть, проверяется глобальная переменная отсутствия линка на ПК и если его не было, глобальная переменная обновляется, а в лог пишется сообщение о том что линк снова появился.
:if ($checklan = 0) do={ :if ($landown != true) do={ /log error "PING LAN FAILED" :set $landown true interface ethernet set eth2-lan disabled=yes :delay 5 interface ethernet set eth2-lan disabled=no :delay 2 }
Если ПК не пингуется и в глобальной переменной не указано что нет линка, то в лог пишется сообщение PING LAN FAILED, делается запись в глобальную переменную, а затем самое интересное. Бывают случаи, когда ПК находится включенным по несколько дней и иногда пропадает интернет, при этом линк на Микротике есть. Лично у меня интернет постоянно пропадал когда истекал срок аренды DHCP, почему то настройки просто не перезапрашивались моим компьютером, поэтому я специально сделал в скрипте проверку «Если линк на ПК есть, но ПК не пингуется — перезагрузить нужный порт на Микротике.» Собственно эти действия и происходят в части скрипта выше.
else={ :if ($landown = true) do={ /log warning "PING LAN OK" :set $landown false } }
Если пинг ПК есть, а до этого не было, в лог пишется сообщение.
Если линка до ПК нет, а до этого он был, то в лог пишется сообщение.
else={ :if ($linkdown != true) do={ /log error "LAN LINK DOWN" :set $linkdown true }
Скрипт добавляется в раздел System->Scripts. Для запуска каждую минуту (или другой промежуток времени) его следует добавить в System->Scheduler.
В On Event пишем:
system script run ping-lan
где ping-lan — название скрипта, которое вы указали при добавлении в System->Scripts.
Полный код скрипта:
:global linkdown:global landown:local checklan [/ping 10.10.1.10 count=5]:local link/interface ethernet cable-test eth2-lan once do={:set $link $"status";}; :if ($link = "link-ok") do={ :if ($linkdown = true) do={ /log warning "LAN LINK UP" :set $linkdown false } :if ($checklan = 0) do={ :if ($landown != true) do={ /log error "PING LAN FAILED" :set $landown true interface ethernet set eth2-lan disabled=yes :delay 5 interface ethernet set eth2-lan disabled=no :delay 2 } } else={ :if ($landown = true) do={ /log warning "PING LAN OK" :set $landown false } }} else={ :if ($linkdown != true) do={ /log error "LAN LINK DOWN" :set $linkdown true }}
Вы можете легко изменить скрипт для мониторинга нескольких устройств в вашей локальной сети. Для этого используйте циклы и массивы. Для проверки наличия интернет-соединения вы можете использовать скрипт или часть скрипта, который я опубликую завтра.
Спасибо alexell