From 896f0b233bace38df523f4fba966b13819b747b5 Mon Sep 17 00:00:00 2001 From: Alexander Bluhm Date: Wed, 24 Jan 2024 00:33:53 +0100 Subject: [PATCH] Parse ping flood values in netlink. --- netlink.pl | 61 ++++++++++++++++++++++++++++++------------------------ 1 file changed, 34 insertions(+), 27 deletions(-) diff --git a/netlink.pl b/netlink.pl index bcf7d85..352fc9e 100755 --- a/netlink.pl +++ b/netlink.pl @@ -733,29 +733,57 @@ sub netbench_parser { return 1; } +sub pingflood_parser { + my ($line, $log) = @_; + my ($min, $avg, $max, $stddev); + if ($line =~ m{^(\d+) packets transmitted, (\d+) received, ([\.\d]+)% packet loss, time ([\.\d]+)ms$}) { + print $tr "VALUE $1 packet transmit\n"; + print $tr "VALUE $2 packet receive\n"; + print $tr "VALUE $3 percent loss\n"; + } + if ($line =~ m{^(\d+) packets transmitted, (\d+) packets received, ([\.\d]+)% packet loss$}) { + print $tr "VALUE $1 packet transmit\n"; + print $tr "VALUE $2 packet receive\n"; + print $tr "VALUE $3 percent loss\n"; + } + if ($line =~ m{^rtt min/avg/max/mdev = ([\.\d]+)/([\.\d]+)/([\.\d]+)/([\.\d]+) ms, ipg/ewma ([\.\d]+)/([\.\d]+) ms$}) { + print $tr "VALUE $1 ms min\n"; + print $tr "VALUE $2 ms avg\n"; + print $tr "VALUE $3 ms max\n"; + print $tr "VALUE $4 ms stddev\n"; + } + if ($line =~ m{^round-trip min/avg/max/std-dev = ([\.\d]+)/([\.\d]+)/([\.\d]+)/([\.\d]+) ms$}) { + print $tr "VALUE $1 ms min\n"; + print $tr "VALUE $2 ms avg\n"; + print $tr "VALUE $3 ms max\n"; + print $tr "VALUE $4 ms stddev\n"; + } + return 1; +} + my @tests; push @tests, ( { testcmd => ['ssh', $lnx_l_ssh, 'ping', '-qfc10000', $obsd_l_addr], - parser => \&ping_f_parser, + parser => \&pingflood_parser, }, { testcmd => ['ping', '-qfc10000', $lnx_r_addr], - parser => \&ping_f_parser, + parser => \&pingflood_parser, }, { testcmd => ['ssh', $lnx_l_ssh, 'ping', '-qfc10000', $lnx_r_addr], - parser => \&ping_f_parser, + parser => \&pingflood_parser, } ) if ($testmode{icmp4}); push @tests, ( { testcmd => ['ssh', $lnx_l_ssh, 'ping6', '-qfc10000', $obsd_l_addr6], - parser => \&ping_f_parser, + parser => \&pingflood_parser, }, { testcmd => ['ping6', '-qfc10000', $lnx_r_addr6], - parser => \&ping_f_parser, + parser => \&pingflood_parser, }, { testcmd => ['ssh', $lnx_l_ssh, 'ping6', '-qfc10000', $lnx_r_addr6], - parser => \&ping_f_parser, + parser => \&pingflood_parser, } ) if ($testmode{icmp6}); push @tests, { @@ -1274,27 +1302,6 @@ sub vmstat_m_tail_1_parser { } } -sub ping_f_parser { - my ($l, $log) = @_; - if ($l =~ m{rtt min/avg/max/mdev = ([\.\d]+)/([\.\d]+)/([\.\d]+)/([\.\d]+) ms, ipg/ewma ([\.\d]+)/([\.\d]+) ms}) { - my $min = $1; - my $avg = $2; - my $max = $3; - my $mdev = $4; - my $ipg = $5; - my $ewma = $6; - print "Ping: $min/$avg/$max/$mdev $ipg/$ewma\n"; - } - if ($l =~ m{round-trip min/avg/max/std-dev = ([\.\d]+)/([\.\d]+)/([\.\d]+)/([\.\d]+) ms}) { - my $min = $1; - my $avg = $2; - my $max = $3; - my $stddev = $4; - print "Ping: $min/$avg/$max/$stddev\n"; - } - return 1; -} - sub printcmd { my @cmd = @_; print "@cmd\n";