Fix #1042
This commit is contained in:
parent
85aa580991
commit
2296a85e95
|
@ -147,11 +147,21 @@ sub custom_usage_calc {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sub custom_access_output {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
my $msg = sprintf("Access : %s",
|
||||||
|
$self->{result_values}->{access_absolute} == 1 ? 'readWrite' : 'readOnly'
|
||||||
|
);
|
||||||
|
|
||||||
|
return $msg;
|
||||||
|
}
|
||||||
|
|
||||||
sub set_counters {
|
sub set_counters {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{maps_counters_type} = [
|
$self->{maps_counters_type} = [
|
||||||
{ name => 'storage', type => 1, cb_prefix_output => 'prefix_storage_output', message_multiple => 'All storages are ok' },
|
{ name => 'storage', type => 1, cb_prefix_output => 'prefix_storage_output', message_multiple => 'All storages are ok', skipped_code => { -10 => 1 } },
|
||||||
];
|
];
|
||||||
|
|
||||||
$self->{maps_counters}->{storage} = [
|
$self->{maps_counters}->{storage} = [
|
||||||
|
@ -163,6 +173,15 @@ sub set_counters {
|
||||||
closure_custom_threshold_check => $self->can('custom_usage_threshold'),
|
closure_custom_threshold_check => $self->can('custom_usage_threshold'),
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
{ label => 'access', set => {
|
||||||
|
key_values => [ { name => 'access' }, { name => 'display' } ],
|
||||||
|
closure_custom_output => $self->can('custom_access_output'),
|
||||||
|
perfdatas => [
|
||||||
|
{ label => 'access', value => 'access_absolute', template => '%d', min => 1, max => 2,
|
||||||
|
label_extra_instance => 1, instance_use => 'display_absolute' },
|
||||||
|
],
|
||||||
|
}
|
||||||
|
},
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -184,23 +203,23 @@ sub new {
|
||||||
bless $self, $class;
|
bless $self, $class;
|
||||||
|
|
||||||
$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' },
|
"reload-cache-time:s" => { name => 'reload_cache_time', default => 180 },
|
||||||
"reload-cache-time:s" => { name => 'reload_cache_time', default => 180 },
|
"name" => { name => 'use_name' },
|
||||||
"name" => { name => 'use_name' },
|
"storage:s" => { name => 'storage' },
|
||||||
"storage:s" => { name => 'storage' },
|
"regexp" => { name => 'use_regexp' },
|
||||||
"regexp" => { name => 'use_regexp' },
|
"regexp-isensitive" => { name => 'use_regexpi' },
|
||||||
"regexp-isensitive" => { name => 'use_regexpi' },
|
"oid-filter:s" => { name => 'oid_filter', default => 'hrStorageDescr'},
|
||||||
"oid-filter:s" => { name => 'oid_filter', default => 'hrStorageDescr'},
|
"oid-display:s" => { name => 'oid_display', default => 'hrStorageDescr'},
|
||||||
"oid-display:s" => { name => 'oid_display', default => 'hrStorageDescr'},
|
"display-transform-src:s" => { name => 'display_transform_src' },
|
||||||
"display-transform-src:s" => { name => 'display_transform_src' },
|
"display-transform-dst:s" => { name => 'display_transform_dst' },
|
||||||
"display-transform-dst:s" => { name => 'display_transform_dst' },
|
"show-cache" => { name => 'show_cache' },
|
||||||
"show-cache" => { name => 'show_cache' },
|
"space-reservation:s" => { name => 'space_reservation' },
|
||||||
"space-reservation:s" => { name => 'space_reservation' },
|
"filter-storage-type:s" => { name => 'filter_storage_type', default => $self->default_storage_type() },
|
||||||
"filter-storage-type:s" => { name => 'filter_storage_type', default => $self->default_storage_type() },
|
"add-access" => { name => 'add_access' },
|
||||||
});
|
});
|
||||||
|
|
||||||
$self->{storage_id_selected} = [];
|
$self->{storage_id_selected} = [];
|
||||||
$self->{statefile_cache} = centreon::plugins::statefile->new(%options);
|
$self->{statefile_cache} = centreon::plugins::statefile->new(%options);
|
||||||
|
@ -233,6 +252,35 @@ sub check_options {
|
||||||
$instance_mode = $self;
|
$instance_mode = $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sub access_result {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
return {}
|
||||||
|
if (!defined($self->{option_results}->{add_access}));
|
||||||
|
my $oid_hrFSAccess = '.1.3.6.1.2.1.25.3.8.1.5';
|
||||||
|
my $relations = $self->{statefile_cache}->get(name => 'relation_storageindex_fsstorageindex');
|
||||||
|
my @instances = [];
|
||||||
|
foreach (@{$self->{storage_id_selected}}) {
|
||||||
|
if (defined($relations->{$_})) {
|
||||||
|
push @instances, $relations->{$_};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
$self->{snmp}->load(
|
||||||
|
oids => [$oid_hrFSAccess],
|
||||||
|
instances => \@instances, nothing_quit => 1
|
||||||
|
);
|
||||||
|
my $snmp_result = $self->{snmp}->get_leef();
|
||||||
|
my $result = {};
|
||||||
|
foreach (@{$self->{storage_id_selected}}) {
|
||||||
|
if (defined($snmp_result->{$oid_hrFSAccess . '.' . $relations->{$_}})) {
|
||||||
|
$result->{$_} = $snmp_result->{$oid_hrFSAccess . '.' . $relations->{$_}};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return $result;
|
||||||
|
}
|
||||||
|
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
@ -243,10 +291,11 @@ sub manage_selection {
|
||||||
my $oid_hrStorageSize = '.1.3.6.1.2.1.25.2.3.1.5';
|
my $oid_hrStorageSize = '.1.3.6.1.2.1.25.2.3.1.5';
|
||||||
my $oid_hrStorageUsed = '.1.3.6.1.2.1.25.2.3.1.6';
|
my $oid_hrStorageUsed = '.1.3.6.1.2.1.25.2.3.1.6';
|
||||||
my $oid_hrStorageType = '.1.3.6.1.2.1.25.2.3.1.2';
|
my $oid_hrStorageType = '.1.3.6.1.2.1.25.2.3.1.2';
|
||||||
|
|
||||||
$self->{snmp}->load(oids => [$oid_hrStorageAllocationUnits, $oid_hrStorageSize, $oid_hrStorageUsed],
|
$self->{snmp}->load(oids => [$oid_hrStorageAllocationUnits, $oid_hrStorageSize, $oid_hrStorageUsed],
|
||||||
instances => $self->{storage_id_selected}, nothing_quit => 1);
|
instances => $self->{storage_id_selected}, nothing_quit => 1);
|
||||||
my $result = $self->{snmp}->get_leef();
|
my $result = $self->{snmp}->get_leef();
|
||||||
|
my $access_result = $self->access_result();
|
||||||
|
|
||||||
$self->{storage} = {};
|
$self->{storage} = {};
|
||||||
foreach (sort @{$self->{storage_id_selected}}) {
|
foreach (sort @{$self->{storage_id_selected}}) {
|
||||||
|
@ -271,6 +320,7 @@ sub manage_selection {
|
||||||
allocation_units => $result->{$oid_hrStorageAllocationUnits . "." . $_},
|
allocation_units => $result->{$oid_hrStorageAllocationUnits . "." . $_},
|
||||||
size => $result->{$oid_hrStorageSize . "." . $_},
|
size => $result->{$oid_hrStorageSize . "." . $_},
|
||||||
used => $result->{$oid_hrStorageUsed . "." . $_},
|
used => $result->{$oid_hrStorageUsed . "." . $_},
|
||||||
|
access => defined($access_result->{$_}) ? $access_result->{$_} : undef,
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -288,18 +338,26 @@ sub reload_cache {
|
||||||
$datas->{oid_display} = $self->{option_results}->{oid_display};
|
$datas->{oid_display} = $self->{option_results}->{oid_display};
|
||||||
$datas->{last_timestamp} = time();
|
$datas->{last_timestamp} = time();
|
||||||
$datas->{all_ids} = [];
|
$datas->{all_ids} = [];
|
||||||
|
$datas->{relation_storageindex_fsstorageindex} = {};
|
||||||
|
|
||||||
my $request = [ { oid => $oids_hrStorageTable{hrstoragetype} } ];
|
my $request = [ { oid => $oids_hrStorageTable{hrstoragetype} } ];
|
||||||
my $added = {};
|
my $added = {};
|
||||||
|
my $build_relation = 0;
|
||||||
foreach (($self->{option_results}->{oid_filter}, $self->{option_results}->{oid_display} )) {
|
foreach (($self->{option_results}->{oid_filter}, $self->{option_results}->{oid_display} )) {
|
||||||
next if (defined($added->{$_}));
|
next if (defined($added->{$_}));
|
||||||
$added->{$_} = 1;
|
$added->{$_} = 1;
|
||||||
if (/hrFSMountPoint/i) {
|
if (/hrFSMountPoint/i) {
|
||||||
push @{$request}, ({ oid => $oids_hrStorageTable{hrfsmountpoint} }, { oid => $oids_hrStorageTable{hrfsstorageindex} });
|
push @{$request}, ({ oid => $oids_hrStorageTable{hrfsmountpoint} }, { oid => $oids_hrStorageTable{hrfsstorageindex} });
|
||||||
|
$build_relation = 1;
|
||||||
} else {
|
} else {
|
||||||
push @{$request}, { oid => $oids_hrStorageTable{hrstoragedescr} };
|
push @{$request}, { oid => $oids_hrStorageTable{hrstoragedescr} };
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (defined($self->{option_results}->{add_access}) && !defined($added->{hrFSMountPoint})) {
|
||||||
|
push @{$request}, { oid => $oids_hrStorageTable{hrfsstorageindex} };
|
||||||
|
$build_relation = 1;
|
||||||
|
}
|
||||||
|
|
||||||
my $result = $self->{snmp}->get_multiple_table(oids => $request);
|
my $result = $self->{snmp}->get_multiple_table(oids => $request);
|
||||||
foreach ((['filter', $self->{option_results}->{oid_filter}], ['display', $self->{option_results}->{oid_display}], ['type', 'hrstoragetype'])) {
|
foreach ((['filter', $self->{option_results}->{oid_filter}], ['display', $self->{option_results}->{oid_display}], ['type', 'hrstoragetype'])) {
|
||||||
|
@ -317,6 +375,13 @@ sub reload_cache {
|
||||||
$datas->{$$_[1] . "_" . $storage_index} = $self->{output}->to_utf8($result->{ $oids_hrStorageTable{$$_[1]} }->{$key});
|
$datas->{$$_[1] . "_" . $storage_index} = $self->{output}->to_utf8($result->{ $oids_hrStorageTable{$$_[1]} }->{$key});
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if ($build_relation == 1) {
|
||||||
|
foreach (keys %{$result->{ $oids_hrStorageTable{hrfsstorageindex} }}) {
|
||||||
|
/\.([0-9]+)$/;
|
||||||
|
$datas->{relation_storageindex_fsstorageindex}->{ $result->{ $oids_hrStorageTable{hrfsstorageindex} }->{$_} } = $1;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (scalar(@{$datas->{all_ids}}) <= 0) {
|
if (scalar(@{$datas->{all_ids}}) <= 0) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Can't construct cache...");
|
$self->{output}->add_option_msg(short_msg => "Can't construct cache...");
|
||||||
|
@ -416,6 +481,19 @@ Threshold warning.
|
||||||
|
|
||||||
Threshold critical.
|
Threshold critical.
|
||||||
|
|
||||||
|
=item B<--warning-access>
|
||||||
|
|
||||||
|
Threshold warning.
|
||||||
|
|
||||||
|
=item B<--critical-access>
|
||||||
|
|
||||||
|
Threshold critical.
|
||||||
|
Check if storage is readOnly: --critical-access=@2:2
|
||||||
|
|
||||||
|
=item B<--add-access>
|
||||||
|
|
||||||
|
Check storage access (readOnly, readWrite).
|
||||||
|
|
||||||
=item B<--units>
|
=item B<--units>
|
||||||
|
|
||||||
Units of thresholds (Default: '%') ('%', 'B').
|
Units of thresholds (Default: '%') ('%', 'B').
|
||||||
|
|
Loading…
Reference in New Issue