Nagios::Plugin::JUNOS, check_junos: Added basic support for excluding targets.

This may be done by prefixing the target name with '~' rather than '+'. For
example, this may be combined with @with_description when checking interfaces
to exclude some specific interface(s): interfaces,@with_description~ge-0/0/0.
This commit is contained in:
Sebastian Harl 2012-08-31 12:09:32 +02:00
parent a14dae1e62
commit 864a0e6dcd
2 changed files with 52 additions and 21 deletions

View file

@ -252,19 +252,20 @@ sub check_interfaces
{ {
my $plugin = shift; my $plugin = shift;
my $junos = shift; my $junos = shift;
my @targets = @_; my $targets = shift || [];
my $exclude = shift || [];
my $opts = { my $opts = {
with_description => 0, with_description => 0,
}; };
if (grep { m/^\@with_description$/; } @targets) { if (grep { m/^\@with_description$/; } @$targets) {
$opts->{'with_description'} = 1; $opts->{'with_description'} = 1;
@targets = grep { ! m/^\@with_description$/; } @targets; @$targets = grep { ! m/^\@with_description$/; } @$targets;
} }
my @interfaces = get_interfaces($plugin, $opts, @targets);; my @interfaces = get_interfaces($plugin, $opts, @$targets);;
my $down_count = 0; my $down_count = 0;
my @down_ifaces = (); my @down_ifaces = ();
@ -277,7 +278,7 @@ sub check_interfaces
foreach my $iface (@interfaces) { foreach my $iface (@interfaces) {
my $name = $plugin->get_query_object_value($iface, 'name'); my $name = $plugin->get_query_object_value($iface, 'name');
my $desc = $plugin->get_query_object_value($iface, 'description'); my $desc = $plugin->get_query_object_value($iface, 'description');
my $status = check_interface($plugin, $iface, $opts, @targets); my $status = check_interface($plugin, $iface, $opts, @$targets);
my $tmp; my $tmp;
@ -339,15 +340,15 @@ sub check_interfaces
} }
if ((! $down_count) && (! $phys_down_count)) { if ((! $down_count) && (! $phys_down_count)) {
if ((! scalar(@targets)) || $opts->{'with_description'}) { if ((! scalar(@$targets)) || $opts->{'with_description'}) {
$plugin->add_message(OK, "all interfaces up" $plugin->add_message(OK, "all interfaces up"
. ($have_lag_ifaces . ($have_lag_ifaces
? " (including all LAG member interfaces)" : "")); ? " (including all LAG member interfaces)" : ""));
} }
else { else {
$plugin->add_message(OK, "interface" $plugin->add_message(OK, "interface"
. (scalar(@targets) == 1 ? " " : "s ") . (scalar(@$targets) == 1 ? " " : "s ")
. join(", ", @targets) . " up" . join(", ", @$targets) . " up"
. ($have_lag_ifaces . ($have_lag_ifaces
? " (including all LAG member interfaces)" : "")); ? " (including all LAG member interfaces)" : ""));
} }
@ -358,7 +359,8 @@ sub check_interface_forwarding
{ {
my $plugin = shift; my $plugin = shift;
my $junos = shift; my $junos = shift;
my @targets = @_; my $targets = shift || [];
my $exclude = shift || [];
my $res = $plugin->send_query('show ethernet-switching interfaces brief'); my $res = $plugin->send_query('show ethernet-switching interfaces brief');
@ -369,7 +371,7 @@ sub check_interface_forwarding
'Storm control in effect' => 1, 'Storm control in effect' => 1,
); );
my %targets = map { my @t = split(':', $_); $t[0] => $t[1]; } @targets; my %targets = map { my @t = split(':', $_); $t[0] => $t[1]; } @$targets;
my @failed = (); my @failed = ();
@ -377,7 +379,7 @@ sub check_interface_forwarding
my $name = $plugin->get_query_object_value($iface, 'interface-name'); my $name = $plugin->get_query_object_value($iface, 'interface-name');
my $failed_status = undef; my $failed_status = undef;
if (scalar(@targets) && (! exists($targets{$name}))) { if (scalar(@$targets) && (! exists($targets{$name}))) {
next; next;
} }
@ -418,7 +420,8 @@ sub check_chassis_environment
{ {
my $plugin = shift; my $plugin = shift;
my $junos = shift; my $junos = shift;
my @targets = @_; my $targets = shift || [];
my $exclude = shift || [];
my $res = $plugin->send_query('get_environment_information'); my $res = $plugin->send_query('get_environment_information');
@ -437,7 +440,7 @@ sub check_chassis_environment
foreach my $item ($plugin->get_query_object($res, 'environment-item')) { foreach my $item ($plugin->get_query_object($res, 'environment-item')) {
my $name = $plugin->get_query_object_value($item, 'name'); my $name = $plugin->get_query_object_value($item, 'name');
if (scalar(@targets) && (! grep { m/^$name$/ } @targets)) { if (scalar(@$targets) && (! grep { m/^$name$/ } @$targets)) {
next; next;
} }
@ -448,7 +451,7 @@ sub check_chassis_environment
my $status = $plugin->get_query_object_value($item, 'status'); my $status = $plugin->get_query_object_value($item, 'status');
if ($status eq "Absent") { if ($status eq "Absent") {
if (! scalar(@targets)) { if (! scalar(@$targets)) {
next; next;
} }
# else: check this component # else: check this component
@ -515,7 +518,8 @@ sub check_system_storage
{ {
my $plugin = shift; my $plugin = shift;
my $junos = shift; my $junos = shift;
my @targets = @_; my $targets = shift || [];
my $exclude = shift || [];
my $res = $plugin->send_query('get_system_storage'); my $res = $plugin->send_query('get_system_storage');
@ -530,8 +534,8 @@ sub check_system_storage
my $name = $plugin->get_query_object_value($fs, 'filesystem-name'); my $name = $plugin->get_query_object_value($fs, 'filesystem-name');
my $mnt_pt = $plugin->get_query_object_value($fs, 'mounted-on'); my $mnt_pt = $plugin->get_query_object_value($fs, 'mounted-on');
if (scalar(@targets) && (! grep { m/^$name$/ } @targets) if (scalar(@$targets) && (! grep { m/^$name$/ } @$targets)
&& (! grep { m/^$mnt_pt$/ } @targets)) { && (! grep { m/^$mnt_pt$/ } @$targets)) {
next; next;
} }

View file

@ -257,7 +257,28 @@ sub _add_single_check
$c{'target'} = undef; $c{'target'} = undef;
if (defined($check[1])) { if (defined($check[1])) {
$c{'target'} = [ split(m/\+/, $check[1]) ]; my @tmp = split(m/(\+|\~)/, $check[1]);
$c{'target'} = [];
$c{'exclude'} = [];
for (my $i = 0; $i < scalar(@tmp); ++$i) {
my $t = $tmp[$i];
if ((($t ne "+") && ($t ne "~")) || ($i == $#tmp)) {
push @{$c{'target'}}, $t;
next;
}
++$i;
if ($t eq "+") {
push @{$c{'target'}}, $tmp[$i];
}
else {
push @{$c{'exclude'}}, $tmp[$i];
}
}
} }
$c{'warning'} = $check[2]; $c{'warning'} = $check[2];
@ -290,6 +311,7 @@ sub set_checks
$self->{'conf'}->{'checks'}->[0] = { $self->{'conf'}->{'checks'}->[0] = {
name => $self->{'default_check'}, name => $self->{'default_check'},
target => [], target => [],
exclude => [],
warning => undef, warning => undef,
critical => undef, critical => undef,
}; };
@ -371,10 +393,15 @@ sub run_checks
my $self = shift; my $self = shift;
foreach my $check ($self->get_checks()) { foreach my $check ($self->get_checks()) {
my @targets = (); my $targets = [];
my $exclude = [];
if (defined $check->{'target'}) { if (defined $check->{'target'}) {
@targets = @{$check->{'target'}}; $targets = $check->{'target'};
}
if (defined $check->{'exclude'}) {
$exclude = $check->{'exclude'};
} }
$self->set_thresholds( $self->set_thresholds(
@ -383,7 +410,7 @@ sub run_checks
); );
my $sub = $self->get_check_impl($check->{'name'}); my $sub = $self->get_check_impl($check->{'name'});
$sub->($self, $self->{'junos'}, @targets); $sub->($self, $self->{'junos'}, $targets, $exclude);
} }
} }