Страница 1 из 1

Скрипт PING с получением avg-rtt и обработкой

Добавлено: 31 мар 2023, 17:15
Sheva
Не могу победить скрипт, прошу помощи.

Пингуем ya.ru 5 пакетов.
Получаем среднюю задержку avg-rtt
сравниваем с :local threshold "50ms"
если задержка выше чем 50мс - пишем лог



:local threshold "50ms"
:local pingResult [/ping ya.ru interval=1 size=64 count=5]

:if (($pingResult->"sent" != "0") and ($pingResult->"received" != "0")) do={
:local avgRtt ($pingResult->"avg-rtt")
:if ([:tonum [:pick $avgRtt 0 [:len $avgRtt-2]]] > [:tonum [:pick $threshold 0 [:len $threshold-2]]]) do={
:log info "Ping to $host is too high: $avgRtt"
}
}

Re: Скрипт PING с получением avg-rtt и обработкой

Добавлено: 31 мар 2023, 19:55
podarok66
А вы уверены, что вы хоть одну на свою переменную вообще получили результат, который ожидали? Например команда :put $pingResult вам бы показада, что эта переменная имеет значение 5, и ничего более. А вы тут из нее какие-то данные ещё вытащить хотите :hi_hi_hi:
Вот точно рабочая конструкция, которая по идее должна дать начало вашему скрипту:

Код: Выделить всё

:local avgRtt;
:local Sent;
:local Received;
/tool flood-ping 8.8.8.8 count=5 do={
:set Sent $"sent";
:set Received $"received";
:set avgRtt $"avg-rtt";
}
Кстати, адрес только в виде IP, остальное не примет. Вы бы проверяли каждую строку и каждый промежуточный результат, таких вопросов стало бы поменьше. А то нагромождение кода с кучей вольностей никого не привлечёт и тема останется безответной.

Re: Скрипт PING с получением avg-rtt и обработкой

Добавлено: 31 мар 2023, 22:16
Sheva
этот скрипт работает:

Код: Выделить всё

{
:local test [:ping [:resolve "ya.ru"] count=6 as-value]
:local avg 0
:local fails 0
:local min 00:00:10
:local max 00:00:00
:foreach try in=$test do={
    :set avg ($avg + ($try->"time"))
    :if ([:typeof ($try->"status")] = "str") do={
        :set fails ($fails + 1)
    } else={
        :if (($try->"time") < $min) do={:set min ($try->"time")}
        :if (($try->"time") > $max) do={:set max ($try->"time")}
    }
}
:set avg ($avg / [:len $test])
:set avg [:pick $avg 0 15]
:put "sent=$[:len $test] received=$([:len $test]-$fails) packet-loss=$(($fails*100)/[:len $test])% min-rtt=$min avg-rtt=$avg max-rtt=$max"
:if ($avg > "00:00:00.070000") do={
 :log info "BAD Ping, Recconect"
   /system script run Recon
}
}

Re: Скрипт PING с получением avg-rtt и обработкой

Добавлено: 08 май 2023, 18:34
DyadyaGenya
Sheva писал(а): 31 мар 2023, 22:16 этот скрипт работает:

Код: Выделить всё

{
:local test [:ping [:resolve "ya.ru"] count=6 as-value]
:local avg 0
:local fails 0
:local min 00:00:10
:local max 00:00:00
:foreach try in=$test do={
    :set avg ($avg + ($try->"time"))
    :if ([:typeof ($try->"status")] = "str") do={
        :set fails ($fails + 1)
    } else={
        :if (($try->"time") < $min) do={:set min ($try->"time")}
        :if (($try->"time") > $max) do={:set max ($try->"time")}
    }
}
:set avg ($avg / [:len $test])
:set avg [:pick $avg 0 15]
:put "sent=$[:len $test] received=$([:len $test]-$fails) packet-loss=$(($fails*100)/[:len $test])% min-rtt=$min avg-rtt=$avg max-rtt=$max"
:if ($avg > "00:00:00.070000") do={
 :log info "BAD Ping, Recconect"
   /system script run Recon
}
}
Что-то не соображу, как сюда добавить сам вывод пингов, тоесть те 6 пингов, которые у вас записаны в каунт