This commit is contained in:
garnier-quentin 2019-06-05 15:41:13 +02:00
parent b5b5e61bfe
commit 38e5ebdfd7
2 changed files with 104 additions and 110 deletions

View File

@ -167,10 +167,11 @@ sub new {
$self->{version} = '1.0'; $self->{version} = '1.0';
$options{options}->add_options(arguments => { $options{options}->add_options(arguments => {
"units:s" => { name => 'units', default => '%' }, 'units:s' => { name => 'units', default => '%' },
"free" => { name => 'free' }, 'free' => { name => 'free' },
"filter-name:s" => { name => 'filter_name' }, 'filter-name:s' => { name => 'filter_name' },
"filter-type:s" => { name => 'filter_type' }, 'filter-type:s' => { name => 'filter_type' },
'filter-vserver:s' => { name => 'filter_vserver' },
}); });
return $self; return $self;
@ -193,6 +194,7 @@ my $mapping2 = {
dfPerCentInodeCapacity => { oid => '.1.3.6.1.4.1.789.1.5.4.1.9' }, dfPerCentInodeCapacity => { oid => '.1.3.6.1.4.1.789.1.5.4.1.9' },
df64TotalKBytes => { oid => '.1.3.6.1.4.1.789.1.5.4.1.29' }, df64TotalKBytes => { oid => '.1.3.6.1.4.1.789.1.5.4.1.29' },
df64UsedKBytes => { oid => '.1.3.6.1.4.1.789.1.5.4.1.30' }, df64UsedKBytes => { oid => '.1.3.6.1.4.1.789.1.5.4.1.30' },
dfVserver => { oid => '.1.3.6.1.4.1.789.1.5.4.1.34' },
dfCompressSavedPercent => { oid => '.1.3.6.1.4.1.789.1.5.4.1.38' }, dfCompressSavedPercent => { oid => '.1.3.6.1.4.1.789.1.5.4.1.38' },
dfDedupeSavedPercent => { oid => '.1.3.6.1.4.1.789.1.5.4.1.40' }, dfDedupeSavedPercent => { oid => '.1.3.6.1.4.1.789.1.5.4.1.40' },
}; };
@ -206,6 +208,7 @@ sub manage_selection {
$mapping2->{dfPerCentInodeCapacity}->{oid}, $mapping2->{dfPerCentInodeCapacity}->{oid},
$mapping2->{dfCompressSavedPercent}->{oid}, $mapping2->{dfCompressSavedPercent}->{oid},
$mapping2->{dfDedupeSavedPercent}->{oid}, $mapping2->{dfDedupeSavedPercent}->{oid},
$mapping2->{dfVserver}->{oid},
); );
if (!$options{snmp}->is_snmpv1()) { if (!$options{snmp}->is_snmpv1()) {
push @oids, $mapping2->{df64TotalKBytes}->{oid}; push @oids, $mapping2->{df64TotalKBytes}->{oid};
@ -215,7 +218,14 @@ sub manage_selection {
my $results; my $results;
if (defined($self->{option_results}->{filter_type}) && $self->{option_results}->{filter_type} ne '') { if (defined($self->{option_results}->{filter_type}) && $self->{option_results}->{filter_type} ne '') {
$results = $options{snmp}->get_multiple_table(oids => [{oid => $mapping->{dfType}->{oid}}, {oid => $mapping2->{dfFileSys}->{oid}}], return_type => 1, nothing_quit => 1); $results = $options{snmp}->get_multiple_table(
oids => [
{ oid => $mapping->{dfType}->{oid} },
{ oid => $mapping2->{dfFileSys}->{oid} }
],
return_type => 1,
nothing_quit => 1
);
} else { } else {
$results = $options{snmp}->get_table(oid => $mapping2->{dfFileSys}->{oid}, nothing_quit => 1); $results = $options{snmp}->get_table(oid => $mapping2->{dfFileSys}->{oid}, nothing_quit => 1);
} }
@ -244,19 +254,25 @@ sub manage_selection {
$self->{fs} = {}; $self->{fs} = {};
$options{snmp}->load(oids => \@oids, instances => \@fs_selected); $options{snmp}->load(oids => \@oids, instances => \@fs_selected);
my $result2 = $options{snmp}->get_leef(nothing_quit => 1); my $snmp_result = $options{snmp}->get_leef(nothing_quit => 1);
foreach my $instance (sort @fs_selected) { foreach my $instance (sort @fs_selected) {
$self->{fs}->{$instance} = { display => $results->{$mapping2->{dfFileSys}->{oid} . '.' . $instance}}; my $result2 = $options{snmp}->map_instance(mapping => $mapping2, results => $snmp_result, instance => $instance);
$self->{fs}->{$instance}->{total} = $result2->{$mapping2->{dfKBytesTotal}->{oid} . '.' . $instance} * 1024;
$self->{fs}->{$instance}->{used} = $result2->{$mapping2->{dfKBytesUsed}->{oid} . '.' . $instance} * 1024; $self->{fs}->{$instance} = {
if (defined($result2->{$mapping2->{df64TotalKBytes}->{oid} . '.' . $instance}) && $result2->{$mapping2->{df64TotalKBytes}->{oid} . '.' . $instance} > 0) { display => defined($result2->{dfVserver}) && $result2->{dfVserver} ne '' ?
$self->{fs}->{$instance}->{total} = $result2->{$mapping2->{df64TotalKBytes}->{oid} . '.' . $instance} * 1024; $result2->{dfVserver} . ':' . $results->{$mapping2->{dfFileSys}->{oid} . '.' . $instance} :
$self->{fs}->{$instance}->{used} = $result2->{$mapping2->{df64UsedKBytes}->{oid} . '.' . $instance} * 1024; $results->{$mapping2->{dfFileSys}->{oid} . '.' . $instance}
};
$self->{fs}->{$instance}->{total} = $result2->{dfKBytesTotal} * 1024;
$self->{fs}->{$instance}->{used} = $result2->{dfKBytesUsed} * 1024;
if (defined($result2->{df64TotalKBytes}) && $result2->{df64TotalKBytes} > 0) {
$self->{fs}->{$instance}->{total} = $result2->{df64TotalKBytes} * 1024;
$self->{fs}->{$instance}->{used} = $result2->{df64UsedKBytes} * 1024;
} }
$self->{fs}->{$instance}->{dfCompressSavedPercent} = $result2->{$mapping2->{dfCompressSavedPercent}->{oid} . '.' . $instance}; $self->{fs}->{$instance}->{dfCompressSavedPercent} = $result2->{dfCompressSavedPercent};
$self->{fs}->{$instance}->{dfDedupeSavedPercent} = $result2->{$mapping2->{dfDedupeSavedPercent}->{oid} . '.' . $instance}; $self->{fs}->{$instance}->{dfDedupeSavedPercent} = $result2->{dfDedupeSavedPercent};
if ($self->{fs}->{$instance}->{total} > 0) { if ($self->{fs}->{$instance}->{total} > 0) {
$self->{fs}->{$instance}->{dfPerCentInodeCapacity} = $result2->{$mapping2->{dfPerCentInodeCapacity}->{oid} . '.' . $instance}; $self->{fs}->{$instance}->{dfPerCentInodeCapacity} = $result2->{dfPerCentInodeCapacity};
} }
} }
} }
@ -293,6 +309,10 @@ Thresholds are on free space left.
Filter by filesystem name (can be a regexp). Filter by filesystem name (can be a regexp).
=item B<--filter-vserver>
Filter by vserver name (can be a regexp).
=item B<--filter-type> =item B<--filter-type>
Filter filesystem type (can be a regexp. Example: 'flexibleVolume|aggregate'). Filter filesystem type (can be a regexp. Example: 'flexibleVolume|aggregate').

View File

@ -25,33 +25,17 @@ use base qw(centreon::plugins::mode);
use strict; use strict;
use warnings; use warnings;
my $oid_dfFileSys = '.1.3.6.1.4.1.789.1.5.4.1.2';
my $oid_dfType = '.1.3.6.1.4.1.789.1.5.4.1.23';
my $oid_dfKBytesTotal = '.1.3.6.1.4.1.789.1.5.4.1.3';
my $oid_df64TotalKBytes = '.1.3.6.1.4.1.789.1.5.4.1.29';
my %map_types = (
1 => 'traditionalVolume',
2 => 'flexibleVolume',
3 => 'aggregate',
4 => 'stripedAggregate',
5 => 'stripedVolume'
);
sub new { sub new {
my ($class, %options) = @_; my ($class, %options) = @_;
my $self = $class->SUPER::new(package => __PACKAGE__, %options); my $self = $class->SUPER::new(package => __PACKAGE__, %options);
bless $self, $class; bless $self, $class;
$self->{version} = '1.0'; $self->{version} = '1.0';
$options{options}->add_options(arguments => $options{options}->add_options(arguments => {
{ 'filter-name:s' => { name => 'filter_name' },
"name:s" => { name => 'name' }, 'filter-type:s' => { name => 'filter_type' },
"regexp" => { name => 'use_regexp' }, 'skip-total-zero' => { name => 'skip_total_zero' },
"type:s" => { name => 'type' },
"skip-total-zero" => { name => 'skip_total_zero' },
}); });
$self->{filesys_id_selected} = [];
return $self; return $self;
} }
@ -61,71 +45,75 @@ sub check_options {
$self->SUPER::init(%options); $self->SUPER::init(%options);
} }
my %map_types = (
1 => 'traditionalVolume',
2 => 'flexibleVolume',
3 => 'aggregate',
4 => 'stripedAggregate',
5 => 'stripedVolume'
);
my $mapping = {
dfFileSys => { oid => '.1.3.6.1.4.1.789.1.5.4.1.2' },
dfKBytesTotal => { oid => '.1.3.6.1.4.1.789.1.5.4.1.3' },
dfType => { oid => '.1.3.6.1.4.1.789.1.5.4.1.23', map => \%map_types },
df64TotalKBytes => { oid => '.1.3.6.1.4.1.789.1.5.4.1.29' },
dfVserver => { oid => '.1.3.6.1.4.1.789.1.5.4.1.34' },
};
sub manage_selection { sub manage_selection {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{result_names} = $self->{snmp}->get_table(oid => $oid_dfFileSys, nothing_quit => 1); my $snmp_result = $options{snmp}->get_multiple_table(
$self->{result_types} = $self->{snmp}->get_table(oid => $oid_dfType, nothing_quit => 1); oids => [
foreach my $oid ($self->{snmp}->oid_lex_sort(keys %{$self->{result_names}})) { { oid => $mapping->{dfFileSys}->{oid} },
next if ($oid !~ /\.([0-9]+)$/); { oid => $mapping->{dfKBytesTotal}->{oid} },
{ oid => $mapping->{dfType}->{oid} },
{ oid => $mapping->{df64TotalKBytes}->{oid} },
{ oid => $mapping->{dfVserver}->{oid} },
],
return_type => 1,
nothing_quit => 1
);
$self->{fs} = {};
foreach my $oid (keys %$snmp_result) {
next if ($oid !~ /^$mapping->{dfFileSys}->{oid}\.(.*)$/);
my $instance = $1; my $instance = $1;
my $type = $map_types{$self->{result_types}->{$oid_dfType . '.' . $instance}}; my $result = $options{snmp}->map_instance(mapping => $mapping, results => $snmp_result, instance => $instance);
# Get all without a name if (defined($self->{option_results}->{filter_name}) && $self->{option_results}->{filter_name} ne '' &&
if (!defined($self->{option_results}->{name})) { $result->{dfFileSys} !~ /$self->{option_results}->{filter_name}/) {
push @{$self->{filesys_id_selected}}, $instance; $self->{output}->output_add(long_msg => "skipping '" . $result->{dfFileSys} . "': no matching filter.", debug => 1);
next;
}
if (defined($self->{option_results}->{filter_type}) && $self->{option_results}->{filter_type} ne '' &&
$result->{dfType} !~ /$self->{option_results}->{filter_type}/) {
$self->{output}->output_add(long_msg => "skipping '" . $result->{dfFileSys} . "': no matching filter.", debug => 1);
next; next;
} }
if (defined($self->{option_results}->{type}) && $type !~ /$self->{option_results}->{type}/i) { $self->{fs}->{$instance} = {
$self->{output}->output_add(long_msg => "Skipping filesys '" . $self->{result_names}->{$oid} . "': no matching filter type"); name => $result->{dfFileSys},
next; total => defined($result->{df64TotalKBytes}) ? $result->{df64TotalKBytes} * 1024 : $result->{dfKBytesTotal} * 1024,
type => $result->{dfType},
vserver => $result->{dfVserver}
};
} }
if (!defined($self->{option_results}->{use_regexp}) && $self->{result_names}->{$oid} ne $self->{option_results}->{name}) {
$self->{output}->output_add(long_msg => "Skipping filesys '" . $self->{result_names}->{$oid} . "': no matching filter name");
next;
}
if (defined($self->{option_results}->{use_regexp}) && $self->{result_names}->{$oid} !~ /$self->{option_results}->{name}/) {
$self->{output}->output_add(long_msg => "Skipping filesys '" . $self->{result_names}->{$oid} . "': no matching filter name (regexp)");
next;
}
push @{$self->{filesys_id_selected}}, $instance;
}
}
sub get_additional_information {
my ($self, %options) = @_;
return if (scalar(@{$self->{filesys_id_selected}}) <= 0);
$self->{snmp}->load(oids => [$oid_dfKBytesTotal], instances => $self->{filesys_id_selected});
if (!$self->{snmp}->is_snmpv1()) {
$self->{snmp}->load(oids => [$oid_df64TotalKBytes], instances => $self->{filesys_id_selected});
}
return $self->{snmp}->get_leef();
} }
sub run { sub run {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{snmp} = $options{snmp};
$self->manage_selection(); $self->manage_selection(%options);
my $result = $self->get_additional_information(); foreach my $instance (sort keys %{$self->{fs}}) {
next if (defined($self->{option_results}->{skip_total_zero}) && $self->{fs}->{$instance}->{total} == 0);
foreach my $instance (sort @{$self->{filesys_id_selected}}) { $self->{output}->output_add(long_msg => '[instance = ' . $instance . '] ' .
my $name = $self->{result_names}->{$oid_dfFileSys . '.' . $instance}; "[name = '" . $self->{fs}->{$instance}->{name} . "'] " .
my $type = $self->{result_types}->{$oid_dfType . '.' . $instance}; "[type = '" . $self->{fs}->{$instance}->{type} . "'] " .
my $total_size = $result->{$oid_dfKBytesTotal . '.' . $instance} * 1024; "[vserver = '" . $self->{fs}->{$instance}->{vserver} . "'] " .
if (defined($result->{$oid_df64TotalKBytes . '.' . $instance}) && $result->{$oid_df64TotalKBytes . '.' . $instance} != 0) { "[total = '" . $self->{fs}->{$instance}->{total} . "']");
$total_size = $result->{$oid_df64TotalKBytes . '.' . $instance} * 1024;
}
if (defined($self->{option_results}->{skip_total_zero}) && $total_size == 0) {
$self->{output}->output_add(long_msg => "Skipping filesys '" . $name . "': total size is 0 and option --skip-total-zero is set");
next;
}
$self->{output}->output_add(long_msg => "'" . $name . "' [total_size = $total_size B] [type = " . $map_types{$type} . "]");
} }
$self->{output}->output_add(severity => 'OK', $self->{output}->output_add(severity => 'OK',
@ -137,27 +125,17 @@ sub run {
sub disco_format { sub disco_format {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{output}->add_disco_format(elements => ['name', 'total', 'type']); $self->{output}->add_disco_format(elements => ['name', 'total', 'type', 'vserver']);
} }
sub disco_show { sub disco_show {
my ($self, %options) = @_; my ($self, %options) = @_;
$self->{snmp} = $options{snmp};
$self->manage_selection(); $self->manage_selection(%options);
my $result = $self->get_additional_information(); foreach my $instance (sort keys %{$self->{fs}}) {
foreach my $instance (sort @{$self->{filesys_id_selected}}) { next if (defined($self->{option_results}->{skip_total_zero}) && $self->{fs}->{$instance}->{total} == 0);
my $name = $self->{result_names}->{$oid_dfFileSys . '.' . $instance};
my $type = $self->{result_types}->{$oid_dfType . '.' . $instance};
my $total_size = $result->{$oid_dfKBytesTotal . '.' . $instance} * 1024;
if (defined($result->{$oid_df64TotalKBytes . '.' . $instance}) && $result->{$oid_df64TotalKBytes . '.' . $instance} != 0) {
$total_size = $result->{$oid_df64TotalKBytes . '.' . $instance} * 1024;
}
next if (defined($self->{option_results}->{skip_total_zero}) && $total_size == 0);
$self->{output}->add_disco_entry(name => $name, $self->{output}->add_disco_entry(%{$self->{fs}->{$instance}});
total => $total_size,
type => $map_types{$type});
} }
} }
@ -171,15 +149,11 @@ List filesystems (volumes and aggregates also).
=over 8 =over 8
=item B<--name> =item B<--filter-name>
Set the filesystem name. Filter the filesystem name.
=item B<--regexp> =item B<--filter-type>
Allows to use regexp to filter filesystem name (with option --name).
=item B<--type>
Filter filesystem type (a regexp. Example: 'flexibleVolume|aggregate'). Filter filesystem type (a regexp. Example: 'flexibleVolume|aggregate').