����JFIF��x�x����'
| Server IP : 78.140.185.180 / Your IP : 216.73.216.170 Web Server : LiteSpeed System : Linux cpanel13.v.fozzy.com 4.18.0-513.11.1.lve.el8.x86_64 #1 SMP Thu Jan 18 16:21:02 UTC 2024 x86_64 User : builderbox ( 1072) PHP Version : 7.3.33 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : ON | Perl : ON | Python : ON | Sudo : OFF | Pkexec : OFF Directory : /proc/1630575/root/proc/1630575/root/proc/self/root/usr/lib64/nagios/plugins/extra/ |
Upload File : |
#!/usr/bin/env perl
use extreme;
use File::Slurp;
use Carp;
use Getopt::Long;
use Sys::Hostname;
use YAML::XS qw(LoadFile Dump);
use SolusVmAPI::Client;
sub help {
print <<EOT;
$0 [--skipolder 15 --netavg 20]
skipolder: SKIP check vms older than VALUE (0 - do not skip any vms)
netavg: percent of VM interface utilization for return critical
Default values:
skipolder: 21
netavg: 10
whitelist: /etc/icinga2/plinc/ddos_vms_wl
For any unspecified params, corresponding default will be used
EOT
exit 3;
}
my ( $skipolder, $netavg, @incidents );
GetOptions(
'h|help' => \&help,
'skipolder=i' => \$skipolder,
'netavg=i' => \$netavg,
);
$netavg //= 10;
$skipolder //= 15;
$skipolder = $skipolder * 86400;
# prepare netinfo
my $cache_file = '/var/tmp/.check_ddos_vms';
my %netinfo = ();
my $cache;
my $datetime = time;
for my $line ( read_file '/proc/net/dev' ) {
$line =~ s/^\s+//;
next if $line !~ m/^kvm|^sol/;
my ( $dev, $rx, $tx ) = ( split /\s+/, $line )[ 0, 1, 10 ];
$dev =~ s/:$//;
$netinfo{$dev}{rx} = $rx;
$netinfo{$dev}{tx} = $tx;
}
# get cache data
unless ( -f $cache_file ) {
write_file( $cache_file, Dump { datetime => time, data => \%netinfo } );
say 'initialization';
exit 3;
}
else {
$cache = LoadFile $cache_file;
}
my @wl = read_file('/etc/icinga2/plinc/ddos_vms_wl') if -f '/etc/icinga2/plinc/ddos_vms_wl';
chomp @wl;
# common
my $hostname = hostname;
my $svmapi = SolusVmAPI::Client->new();
my $out = $svmapi->get("vms-list/$hostname/ddos");
my $diff_sec = $datetime - $cache->{datetime};
for ( keys $out->{'vms-list'}->%* ) {
my $vm = $out->{'vms-list'}->{$_}->{'vm'};
my $ip = $out->{'vms-list'}->{$_}->{'ip'};
my $cdate = $out->{'vms-list'}->{$_}->{'creationdate'};
my $networkspeed = $out->{'vms-list'}->{$_}->{'networkspeed'};
my $vm_dev;
$out->{'vms-list'}->{$_}->{'lvm'} =~ m/^kvm/
? ($vm_dev = $out->{'vms-list'}->{$_}->{'lvm'}) =~ s/_img$/.0/
: ($vm_dev = "sol-$out->{'vms-list'}->{$_}->{'lvm'}") =~ s/_0$//;
last if $cdate && $skipolder != 0 && $cdate < time() - $skipolder;
$networkspeed //= 100;
next if $vm ~~ @wl;
next unless $cache->{data}{$vm_dev};
my $cached = $cache->{data}{$vm_dev};
my $cur = $netinfo{$vm_dev};
my $bytes
= ( $cur->{rx} + $cur->{tx} ) - ( $cached->{rx} + $cached->{tx} );
my $mbit = int $bytes / 125000;
my $ms = int( $mbit / $diff_sec );
my $perc = $ms / $networkspeed * 100;
next if $perc < $netavg;
push @incidents,
"$vm/$ip: net load: $ms Mbit/s (${perc}% of ${networkspeed}Mbit/s) for $diff_sec seconds";
}
# write cache
write_file( $cache_file, Dump { datetime => time, data => \%netinfo } );
if (@incidents) {
say join( "\n", @incidents );
exit 2;
}
say 'OK';
exit 0;