(plugin) storage::huawei::oceanstor - mode luns minor fixes (#4012)
This commit is contained in:
parent
24bf3bd9a6
commit
8b5b174800
|
@ -30,8 +30,7 @@ sub new {
|
||||||
my $self = $class->SUPER::new(package => __PACKAGE__, %options);
|
my $self = $class->SUPER::new(package => __PACKAGE__, %options);
|
||||||
bless $self, $class;
|
bless $self, $class;
|
||||||
|
|
||||||
$options{options}->add_options(arguments => {
|
$options{options}->add_options(arguments => {});
|
||||||
});
|
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
@ -53,15 +52,14 @@ my $oid_lun_entry = '.1.3.6.1.4.1.34774.4.1.23.4.8.1'; # hwInfoLunTable
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $snmp_result = $options{snmp}->get_table(
|
my $snmp_result = $options{snmp}->get_table(oid => $oid_lun_entry);
|
||||||
oid => $oid_lun_entry
|
|
||||||
);
|
|
||||||
|
|
||||||
my $lun = {};
|
my $lun = {};
|
||||||
foreach my $oid (keys %$snmp_result) {
|
foreach my $oid (keys %$snmp_result) {
|
||||||
next if ($oid !~ /^$mapping->{name}->{oid}\.(.*)$/);
|
next if ($oid !~ /^$mapping->{name}->{oid}\.(.*)$/);
|
||||||
my $result = $options{snmp}->map_instance(mapping => $mapping, results => $snmp_result, instance => $1);
|
my $result = $options{snmp}->map_instance(mapping => $mapping, results => $snmp_result, instance => $1);
|
||||||
if($result->{isexposed} == 0) {next;}
|
next if ($result->{isexposed} == 0);
|
||||||
|
|
||||||
$lun->{$1} = $result;
|
$lun->{$1} = $result;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -104,9 +102,7 @@ sub disco_show {
|
||||||
|
|
||||||
my $lun = $self->manage_selection(%options);
|
my $lun = $self->manage_selection(%options);
|
||||||
foreach (sort keys %$lun) {
|
foreach (sort keys %$lun) {
|
||||||
$self->{output}->add_disco_entry(
|
$self->{output}->add_disco_entry(%{$lun->{$_}});
|
||||||
%{$lun->{$_}}
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -116,11 +112,10 @@ __END__
|
||||||
|
|
||||||
=head1 MODE
|
=head1 MODE
|
||||||
|
|
||||||
List storage pools.
|
List LUNs.
|
||||||
|
|
||||||
=over 8
|
=over 8
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
||||||
|
|
|
@ -24,18 +24,6 @@ use base qw(centreon::plugins::templates::counter);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use centreon::plugins::templates::catalog_functions qw(catalog_status_calc);
|
|
||||||
#use storage::huawei::oceanstor::snmp::mode::resources qw($health_status $running_status);
|
|
||||||
|
|
||||||
#sub custom_status_output {
|
|
||||||
# my ($self, %options) = @_;
|
|
||||||
|
|
||||||
#return sprintf(
|
|
||||||
# 'health status: %s [running status: %s]',
|
|
||||||
# $self->{result_values}->{health_status},
|
|
||||||
# $self->{result_values}->{running_status}
|
|
||||||
# );
|
|
||||||
#}
|
|
||||||
|
|
||||||
sub custom_space_usage_output {
|
sub custom_space_usage_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
@ -49,7 +37,7 @@ sub custom_space_usage_output {
|
||||||
$total_size_value . " " . $total_size_unit,
|
$total_size_value . " " . $total_size_unit,
|
||||||
$total_used_value . " " . $total_used_unit, $self->{result_values}->{prct_used_space},
|
$total_used_value . " " . $total_used_unit, $self->{result_values}->{prct_used_space},
|
||||||
$total_free_value . " " . $total_free_unit, $self->{result_values}->{prct_free_space},
|
$total_free_value . " " . $total_free_unit, $self->{result_values}->{prct_free_space},
|
||||||
$total_prot_value . " " . $total_prot_unit, $self->{result_values}->{prot_space}
|
$total_prot_value . " " . $total_prot_unit
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -96,7 +84,7 @@ sub set_counters {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{ label => 'space-usage-free', nlabel => 'lun.space.free.bytes', display_ok => 0, set => {
|
{ label => 'space-usage-free', nlabel => 'lun.space.free.bytes', display_ok => 0, set => {
|
||||||
key_values => [ { name => 'free_space' }, { name => 'used_space' }, { name => 'prct_used_space' }, { name => 'prct_free_space' }, { name => 'total_space' },{ name => 'prot_space' } ],
|
key_values => [ { name => 'free_space' }, { name => 'used_space' }, { name => 'prct_used_space' }, { name => 'prct_free_space' }, { name => 'total_space' }, { name => 'prot_space' } ],
|
||||||
closure_custom_output => $self->can('custom_space_usage_output'),
|
closure_custom_output => $self->can('custom_space_usage_output'),
|
||||||
perfdatas => [
|
perfdatas => [
|
||||||
{ template => '%d', min => 0, max => 'total_space', unit => 'B', cast_int => 1, label_extra_instance => 1 }
|
{ template => '%d', min => 0, max => 'total_space', unit => 'B', cast_int => 1, label_extra_instance => 1 }
|
||||||
|
@ -104,7 +92,7 @@ sub set_counters {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{ label => 'space-usage-prct', nlabel => 'lun.space.usage.percentage', display_ok => 0, set => {
|
{ label => 'space-usage-prct', nlabel => 'lun.space.usage.percentage', display_ok => 0, set => {
|
||||||
key_values => [ { name => 'prct_used_space' }, { name => 'used_space' }, { name => 'free_space' }, { name => 'prct_free_space' }, { name => 'total_space' },{ name => 'prot_space' } ],
|
key_values => [ { name => 'prct_used_space' }, { name => 'used_space' }, { name => 'free_space' }, { name => 'prct_free_space' }, { name => 'total_space' }, { name => 'prot_space' } ],
|
||||||
closure_custom_output => $self->can('custom_space_usage_output'),
|
closure_custom_output => $self->can('custom_space_usage_output'),
|
||||||
perfdatas => [
|
perfdatas => [
|
||||||
{ template => '%.2f', min => 0, max => 100, unit => '%', label_extra_instance => 1 }
|
{ template => '%.2f', min => 0, max => 100, unit => '%', label_extra_instance => 1 }
|
||||||
|
@ -112,7 +100,7 @@ sub set_counters {
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
{ label => 'space-usage-prot', nlabel => 'lun.space.prot.bytes', display_ok => 0, set => {
|
{ label => 'space-usage-prot', nlabel => 'lun.space.prot.bytes', display_ok => 0, set => {
|
||||||
key_values => [ { name => 'prot_space' }, { name => 'used_space' }, { name => 'prct_used_space' }, { name => 'prct_free_space' }, { name => 'total_space' },{ name => 'free_space' } ],
|
key_values => [ { name => 'prot_space' }, { name => 'used_space' }, { name => 'prct_used_space' }, { name => 'prct_free_space' }, { name => 'total_space' }, { name => 'free_space' } ],
|
||||||
closure_custom_output => $self->can('custom_space_usage_output'),
|
closure_custom_output => $self->can('custom_space_usage_output'),
|
||||||
perfdatas => [
|
perfdatas => [
|
||||||
{ template => '%d', min => 0, max => 'total_space', unit => 'B', cast_int => 1, label_extra_instance => 1 }
|
{ template => '%d', min => 0, max => 'total_space', unit => 'B', cast_int => 1, label_extra_instance => 1 }
|
||||||
|
@ -144,7 +132,6 @@ my $mapping = {
|
||||||
exposed => { oid => '.1.3.6.1.4.1.34774.4.1.23.4.8.1.14' } # hwInfoLunExposedToInitiator
|
exposed => { oid => '.1.3.6.1.4.1.34774.4.1.23.4.8.1.14' } # hwInfoLunExposedToInitiator
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
@ -153,7 +140,6 @@ sub manage_selection {
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
my $oid_sp_entry = '.1.3.6.1.4.1.34774.4.1.23.4.8.1'; # hwInfoLunTable
|
my $oid_sp_entry = '.1.3.6.1.4.1.34774.4.1.23.4.8.1'; # hwInfoLunTable
|
||||||
my $snmp_result = $options{snmp}->get_table(
|
my $snmp_result = $options{snmp}->get_table(
|
||||||
oid => $oid_sp_entry,
|
oid => $oid_sp_entry,
|
||||||
|
@ -161,43 +147,32 @@ sub manage_selection {
|
||||||
);
|
);
|
||||||
|
|
||||||
$self->{lun} = {};
|
$self->{lun} = {};
|
||||||
|
|
||||||
foreach my $oid (keys %$snmp_result) {
|
foreach my $oid (keys %$snmp_result) {
|
||||||
next if ($oid !~ /^$mapping->{name}->{oid}\.(.*)$/);
|
next if ($oid !~ /^$mapping->{name}->{oid}\.(.*)$/);
|
||||||
|
|
||||||
my $result = $options{snmp}->map_instance(mapping => $mapping, results => $snmp_result, instance => $1);
|
my $result = $options{snmp}->map_instance(mapping => $mapping, results => $snmp_result, instance => $1);
|
||||||
|
|
||||||
if (defined($self->{option_results}->{filter_name}) && $self->{option_results}->{filter_name} ne '' &&
|
if (defined($self->{option_results}->{filter_name}) && $self->{option_results}->{filter_name} ne '' &&
|
||||||
$result->{name} !~ /$self->{option_results}->{filter_name}/) {
|
$result->{name} !~ /$self->{option_results}->{filter_name}/) {
|
||||||
$self->{output}->output_add(long_msg => "skipping LUN '" . $result->{name} . "'.", debug => 1);
|
$self->{output}->output_add(long_msg => "skipping LUN '" . $result->{name} . "'.", debug => 1);
|
||||||
next;
|
next;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!defined($self->{option_results}->{include_non_exposed_luns}) && $result->{exposed} == 0){
|
if (!defined($self->{option_results}->{include_non_exposed_luns}) && $result->{exposed} == 0) {
|
||||||
$self->{output}->output_add(long_msg => "skipping LUN '" . $result->{name} . "'.", debug => 1);
|
$self->{output}->output_add(long_msg => "skipping LUN '" . $result->{name} . "'.", debug => 1);
|
||||||
next;
|
next;
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{lun}->{$result->{name}} = $result; # if(defined($1));
|
$result->{total_space} *= 1024 * 1024;
|
||||||
}
|
$result->{used_space} *= 1024 * 1024;
|
||||||
|
$result->{prot_space} *= 1024;
|
||||||
foreach (keys %{$self->{lun}}) {
|
$self->{lun}->{ $result->{name} } = {
|
||||||
|
name => $result->{name},
|
||||||
my $result = $self->{lun}->{$_};
|
storage_pool => $result->{storage_pool},
|
||||||
$result->{total_space} *=1024*1024;
|
space => $result
|
||||||
$result->{used_space} *=1024*1024;
|
|
||||||
my $free_space=$result->{total_space} - $result->{used_space};
|
|
||||||
|
|
||||||
$self->{lun}->{$_}->{space} = {
|
|
||||||
name => $_,
|
|
||||||
total_space => $result->{total_space},
|
|
||||||
used_space => $result->{used_space},
|
|
||||||
free_space => $free_space,
|
|
||||||
prot_space => $result->{prot_space}*1024,
|
|
||||||
prct_used_space => 100 - ($free_space * 100 / $result->{total_space}),
|
|
||||||
prct_free_space => ($free_space * 100 / $result->{total_space})
|
|
||||||
};
|
};
|
||||||
|
$self->{lun}->{ $result->{name} }->{space}->{free_space} = $result->{total_space} - $result->{used_space};
|
||||||
|
$self->{lun}->{ $result->{name} }->{space}->{prct_used_space} = $result->{used_space} * 100 / $result->{total_space};
|
||||||
|
$self->{lun}->{ $result->{name} }->{space}->{prct_free_space} = 100 - $result->{used_space};
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -207,7 +182,7 @@ __END__
|
||||||
|
|
||||||
=head1 MODE
|
=head1 MODE
|
||||||
|
|
||||||
Check storage pools.
|
Check LUNs.
|
||||||
|
|
||||||
=over 8
|
=over 8
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue