fix new ssh backend custom
This commit is contained in:
parent
8fead5fb3e
commit
c707f41f73
|
@ -0,0 +1,187 @@
|
||||||
|
#
|
||||||
|
# Copyright 2020 Centreon (http://www.centreon.com/)
|
||||||
|
#
|
||||||
|
# Centreon is a full-fledged industry-strength solution that meets
|
||||||
|
# the needs in IT infrastructure and application monitoring for
|
||||||
|
# service performance.
|
||||||
|
#
|
||||||
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
||||||
|
# you may not use this file except in compliance with the License.
|
||||||
|
# You may obtain a copy of the License at
|
||||||
|
#
|
||||||
|
# http://www.apache.org/licenses/LICENSE-2.0
|
||||||
|
#
|
||||||
|
# Unless required by applicable law or agreed to in writing, software
|
||||||
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
||||||
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
||||||
|
# See the License for the specific language governing permissions and
|
||||||
|
# limitations under the License.
|
||||||
|
#
|
||||||
|
|
||||||
|
package storage::quantum::dxi::ssh::custom::api;
|
||||||
|
|
||||||
|
use strict;
|
||||||
|
use warnings;
|
||||||
|
use centreon::plugins::ssh;
|
||||||
|
use centreon::plugins::misc;
|
||||||
|
|
||||||
|
sub new {
|
||||||
|
my ($class, %options) = @_;
|
||||||
|
my $self = {};
|
||||||
|
bless $self, $class;
|
||||||
|
|
||||||
|
if (!defined($options{output})) {
|
||||||
|
print "Class Custom: Need to specify 'output' argument.\n";
|
||||||
|
exit 3;
|
||||||
|
}
|
||||||
|
if (!defined($options{options})) {
|
||||||
|
$options{output}->add_option_msg(short_msg => "Class Custom: Need to specify 'options' argument.");
|
||||||
|
$options{output}->option_exit();
|
||||||
|
}
|
||||||
|
|
||||||
|
if (!defined($options{noptions})) {
|
||||||
|
$options{options}->add_options(arguments => {
|
||||||
|
'hostname:s' => { name => 'hostname' },
|
||||||
|
'timeout:s' => { name => 'timeout', default => 30 },
|
||||||
|
'sudo' => { name => 'sudo' },
|
||||||
|
'command:s' => { name => 'command' },
|
||||||
|
'command-path:s' => { name => 'command_path' },
|
||||||
|
'command-options:s' => { name => 'command_options' }
|
||||||
|
});
|
||||||
|
}
|
||||||
|
$options{options}->add_help(package => __PACKAGE__, sections => 'QUANTUM OPTIONS', once => 1);
|
||||||
|
|
||||||
|
$self->{output} = $options{output};
|
||||||
|
$self->{mode} = $options{mode};
|
||||||
|
$self->{ssh} = centreon::plugins::ssh->new(%options);
|
||||||
|
|
||||||
|
return $self;
|
||||||
|
}
|
||||||
|
|
||||||
|
sub set_options {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
$self->{option_results} = $options{option_results};
|
||||||
|
}
|
||||||
|
|
||||||
|
sub set_defaults {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
foreach (keys %{$options{default}}) {
|
||||||
|
if ($_ eq $self->{mode}) {
|
||||||
|
for (my $i = 0; $i < scalar(@{$options{default}->{$_}}); $i++) {
|
||||||
|
foreach my $opt (keys %{$options{default}->{$_}[$i]}) {
|
||||||
|
if (!defined($self->{option_results}->{$opt}[$i])) {
|
||||||
|
$self->{option_results}->{$opt}[$i] = $options{default}->{$_}[$i]->{$opt};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
sub check_options {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
if (defined($self->{option_results}->{hostname}) && $self->{option_results}->{hostname} ne '') {
|
||||||
|
$self->{ssh}->check_options(option_results => $self->{option_results});
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
sub convert_to_bytes {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
my ($value, $unit) = split(/\s+/, $options{raw_value});
|
||||||
|
if ($unit =~ /kb*/i) {
|
||||||
|
$value = $value * 1024;
|
||||||
|
} elsif ($unit =~ /mb*/i) {
|
||||||
|
$value = $value * 1024 * 1024;
|
||||||
|
} elsif ($unit =~ /gb*/i) {
|
||||||
|
$value = $value * 1024 * 1024 * 1024;
|
||||||
|
} elsif ($unit =~ /tb*/i) {
|
||||||
|
$value = $value * 1024 * 1024 * 1024 * 1024;
|
||||||
|
}
|
||||||
|
|
||||||
|
return $value;
|
||||||
|
}
|
||||||
|
|
||||||
|
sub execute_command {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
my $content;
|
||||||
|
if (defined($self->{option_results}->{hostname}) && $self->{option_results}->{hostname} ne '') {
|
||||||
|
($content) = $self->{ssh}->execute(
|
||||||
|
hostname => $self->{option_results}->{hostname},
|
||||||
|
command => defined($self->{option_results}->{command}) && $self->{option_results}->{command} ne '' ? $self->{option_results}->{command} : $options{command},
|
||||||
|
command_path => $self->{option_results}->{command_path},
|
||||||
|
command_options => defined($self->{option_results}->{command_options}) && $self->{option_results}->{command_options} ne '' ? $self->{option_results}->{command_options} : undef,
|
||||||
|
timeout => $self->{option_results}->{timeout},
|
||||||
|
sudo => $self->{option_results}->{sudo}
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
if (!defined($self->{option_results}->{command}) || $self->{option_results}->{command} eq '') {
|
||||||
|
$self->{output}->add_option_msg(short_msg => 'please set --hostname option for ssh connection (or --command for local)');
|
||||||
|
$self->{output}->option_exit();
|
||||||
|
}
|
||||||
|
($content) = centreon::plugins::misc::execute(
|
||||||
|
output => $self->{output},
|
||||||
|
options => { timeout => $self->{option_results}->{timeout} },
|
||||||
|
sudo => $self->{option_results}->{sudo},
|
||||||
|
command => $self->{option_results}->{command},
|
||||||
|
command_path => $self->{option_results}->{command_path},
|
||||||
|
command_options => defined($self->{option_results}->{command_options}) && $self->{option_results}->{command_options} ne '' ? $self->{option_results}->{command_options} : undef
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
return $content;
|
||||||
|
}
|
||||||
|
|
||||||
|
1;
|
||||||
|
|
||||||
|
__END__
|
||||||
|
|
||||||
|
=head1 NAME
|
||||||
|
|
||||||
|
quantum dxi
|
||||||
|
|
||||||
|
=head1 SYNOPSIS
|
||||||
|
|
||||||
|
quantum dxi
|
||||||
|
|
||||||
|
=head1 QUANTUM OPTIONS
|
||||||
|
|
||||||
|
=over 8
|
||||||
|
|
||||||
|
=item B<--hostname>
|
||||||
|
|
||||||
|
Hostname to query.
|
||||||
|
|
||||||
|
=item B<--timeout>
|
||||||
|
|
||||||
|
Timeout in seconds for the command (Default: 30).
|
||||||
|
|
||||||
|
=item B<--sudo>
|
||||||
|
|
||||||
|
Use 'sudo' to execute the command.
|
||||||
|
|
||||||
|
=item B<--command>
|
||||||
|
|
||||||
|
Command to get information. Used it you have output in a file.
|
||||||
|
|
||||||
|
=item B<--command-path>
|
||||||
|
|
||||||
|
Command path.
|
||||||
|
|
||||||
|
=item B<--command-options>
|
||||||
|
|
||||||
|
Command options.
|
||||||
|
|
||||||
|
=back
|
||||||
|
|
||||||
|
=head1 DESCRIPTION
|
||||||
|
|
||||||
|
B<custom>.
|
||||||
|
|
||||||
|
=cut
|
|
@ -29,8 +29,7 @@ use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold)
|
||||||
sub custom_status_output {
|
sub custom_status_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $msg = 'Compaction status: ' . $self->{result_values}->{compaction_status};
|
return 'Compaction status: ' . $self->{result_values}->{compaction_status};
|
||||||
return $msg;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_status_calc {
|
sub custom_status_calc {
|
||||||
|
@ -43,56 +42,40 @@ sub custom_status_calc {
|
||||||
sub custom_volume_perfdata {
|
sub custom_volume_perfdata {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{output}->perfdata_add(label => $self->{result_values}->{label}, unit => 'B',
|
$self->{output}->perfdata_add(
|
||||||
value => $self->{result_values}->{volume},
|
label => $self->{result_values}->{label}, unit => 'B',
|
||||||
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{label}),
|
value => $self->{result_values}->{volume},
|
||||||
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{label})
|
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{label}),
|
||||||
);
|
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{label})
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_volume_threshold {
|
sub custom_volume_threshold {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $exit = $self->{perfdata}->threshold_check(value => $self->{result_values}->{volume},
|
return $self->{perfdata}->threshold_check(
|
||||||
threshold => [ { label => 'critical-' . $self->{label}, exit_litteral => 'critical' }, { label => 'warning-'. $self->{label}, exit_litteral => 'warning' } ]);
|
value => $self->{result_values}->{volume},
|
||||||
return $exit;
|
threshold => [ { label => 'critical-' . $self->{label}, exit_litteral => 'critical' }, { label => 'warning-'. $self->{label}, exit_litteral => 'warning' } ]
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_volume_output {
|
sub custom_volume_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my ($volume_value, $volume_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{volume});
|
my ($volume_value, $volume_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{volume});
|
||||||
my $msg = sprintf("%s: %s %s", $self->{result_values}->{display}, $volume_value, $volume_unit);
|
return sprintf('%s: %s %s', $self->{result_values}->{display}, $volume_value, $volume_unit);
|
||||||
return $msg;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_volume_calc {
|
sub custom_volume_calc {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{result_values}->{volume} = $self->{instance_mode}->convert_to_bytes(raw_value => $options{new_datas}->{$self->{instance} . '_' . $options{extra_options}->{label_ref}});
|
$self->{result_values}->{volume} = $options{new_datas}->{$self->{instance} . '_' . $options{extra_options}->{label_ref}};
|
||||||
$self->{result_values}->{display} = $options{extra_options}->{display_ref};
|
$self->{result_values}->{display} = $options{extra_options}->{display_ref};
|
||||||
$self->{result_values}->{label} = $options{extra_options}->{label_ref};
|
$self->{result_values}->{label} = $options{extra_options}->{label_ref};
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
sub convert_to_bytes {
|
|
||||||
my ($class, %options) = @_;
|
|
||||||
|
|
||||||
my ($value, $unit) = split(/\s+/, $options{raw_value});
|
|
||||||
if ($unit =~ /kb*/i) {
|
|
||||||
$value = $value * 1024;
|
|
||||||
} elsif ($unit =~ /mb*/i) {
|
|
||||||
$value = $value * 1024 * 1024;
|
|
||||||
} elsif ($unit =~ /gb*/i) {
|
|
||||||
$value = $value * 1024 * 1024 * 1024;
|
|
||||||
} elsif ($unit =~ /tb*/i) {
|
|
||||||
$value = $value * 1024 * 1024 * 1024 * 1024;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $value;
|
|
||||||
}
|
|
||||||
|
|
||||||
sub set_counters {
|
sub set_counters {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
@ -144,20 +127,10 @@ 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 => {
|
||||||
{
|
'warning-status:s' => { name => 'warning_status', default => '' },
|
||||||
"hostname:s" => { name => 'hostname' },
|
'critical-status:s' => { name => 'critical_status', default => '%{compaction_status} !~ /ready/i' },
|
||||||
"ssh-option:s@" => { name => 'ssh_option' },
|
});
|
||||||
"ssh-path:s" => { name => 'ssh_path' },
|
|
||||||
"ssh-command:s" => { name => 'ssh_command', default => 'ssh' },
|
|
||||||
"timeout:s" => { name => 'timeout', default => 30 },
|
|
||||||
"sudo" => { name => 'sudo' },
|
|
||||||
"command:s" => { name => 'command', default => 'syscli' },
|
|
||||||
"command-path:s" => { name => 'command_path' },
|
|
||||||
"command-options:s" => { name => 'command_options', default => '--getstatus compaction' },
|
|
||||||
"warning-status:s" => { name => 'warning_status', default => '' },
|
|
||||||
"critical-status:s" => { name => 'critical_status', default => '%{compaction_status} !~ /ready/i' },
|
|
||||||
});
|
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
@ -166,25 +139,13 @@ sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::check_options(%options);
|
$self->SUPER::check_options(%options);
|
||||||
|
|
||||||
if (defined($self->{option_results}->{hostname}) && $self->{option_results}->{hostname} ne '') {
|
|
||||||
$self->{option_results}->{remote} = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
$self->change_macros(macros => ['warning_status', 'critical_status']);
|
$self->change_macros(macros => ['warning_status', 'critical_status']);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{global} = {};
|
my $stdout = $options{custom}->execute_command(command => 'syscli --getstatus compaction');
|
||||||
|
|
||||||
my ($stdout, $exit_code) = centreon::plugins::misc::execute(output => $self->{output},
|
|
||||||
options => $self->{option_results},
|
|
||||||
sudo => $self->{option_results}->{sudo},
|
|
||||||
command => $self->{option_results}->{command},
|
|
||||||
command_path => $self->{option_results}->{command_path},
|
|
||||||
command_options => $self->{option_results}->{command_options},
|
|
||||||
);
|
|
||||||
# Output data:
|
# Output data:
|
||||||
# Compaction Status = Ready
|
# Compaction Status = Ready
|
||||||
# Status Progress = 0 %
|
# Status Progress = 0 %
|
||||||
|
@ -193,11 +154,12 @@ sub manage_selection {
|
||||||
# Compacted = 12.00 MB
|
# Compacted = 12.00 MB
|
||||||
# Still to compact = 123.00 MB
|
# Still to compact = 123.00 MB
|
||||||
|
|
||||||
|
$self->{global} = {};
|
||||||
foreach (split(/\n/, $stdout)) {
|
foreach (split(/\n/, $stdout)) {
|
||||||
$self->{global}->{compaction_status} = $1 if ($_ =~ /.*Compaction\sStatus\s=\s(.*)$/i);
|
$self->{global}->{compaction_status} = $1 if (/.*Compaction\sStatus\s=\s(.*)$/i);
|
||||||
$self->{global}->{status_progress} = $1 if ($_ =~ /.*Status\sProgress\s=\s(.*)\s%$/i);
|
$self->{global}->{status_progress} = $1 if (/.*Status\sProgress\s=\s(.*)\s%$/i);
|
||||||
$self->{global}->{compacted} = $1 if ($_ =~ /.*Compacted\s=\s(.*)$/i);
|
$self->{global}->{compacted} = $options{custom}->convert_to_bytes(raw_value => $1) if (/.*Compacted\s=\s(.*)$/i);
|
||||||
$self->{global}->{still_to_compact} = $1 if ($_ =~ /.*Still\sto\scompact\s=\s(.*)$/i);
|
$self->{global}->{still_to_compact} = $options{custom}->convert_to_bytes(raw_value => $1) if (/.*Still\sto\scompact\s=\s(.*)$/i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -211,10 +173,6 @@ Check compaction status and volumes.
|
||||||
|
|
||||||
=over 8
|
=over 8
|
||||||
|
|
||||||
=item B<--hostname>
|
|
||||||
|
|
||||||
Hostname to query.
|
|
||||||
|
|
||||||
=item B<--filter-counters>
|
=item B<--filter-counters>
|
||||||
|
|
||||||
Only display some counters (regexp can be used).
|
Only display some counters (regexp can be used).
|
||||||
|
@ -230,48 +188,11 @@ Can used special variables like: %{compaction_status}
|
||||||
Set critical threshold for status (Default: '%{compaction_status} !~ /ready/i').
|
Set critical threshold for status (Default: '%{compaction_status} !~ /ready/i').
|
||||||
Can used special variables like: %{compaction_status}
|
Can used special variables like: %{compaction_status}
|
||||||
|
|
||||||
=item B<--warning-*>
|
=item B<--warning-*> B<--critical-*>
|
||||||
|
|
||||||
Threshold warning.
|
Thresholds.
|
||||||
Can be: 'status-progress', 'compacted', 'still-to-compact'.
|
Can be: 'status-progress', 'compacted', 'still-to-compact'.
|
||||||
|
|
||||||
=item B<--critical-*>
|
|
||||||
|
|
||||||
Threshold critical.
|
|
||||||
Can be: 'status-progress', 'compacted', 'still-to-compact'.
|
|
||||||
|
|
||||||
=item B<--ssh-option>
|
|
||||||
|
|
||||||
Specify multiple options like the user (example: --ssh-option='-l=centreon-engine' --ssh-option='-p=52').
|
|
||||||
|
|
||||||
=item B<--ssh-path>
|
|
||||||
|
|
||||||
Specify ssh command path (default: none)
|
|
||||||
|
|
||||||
=item B<--ssh-command>
|
|
||||||
|
|
||||||
Specify ssh command (default: 'ssh'). Useful to use 'plink'.
|
|
||||||
|
|
||||||
=item B<--timeout>
|
|
||||||
|
|
||||||
Timeout in seconds for the command (Default: 30).
|
|
||||||
|
|
||||||
=item B<--sudo>
|
|
||||||
|
|
||||||
Use 'sudo' to execute the command.
|
|
||||||
|
|
||||||
=item B<--command>
|
|
||||||
|
|
||||||
Command to get information (Default: 'syscli').
|
|
||||||
|
|
||||||
=item B<--command-path>
|
|
||||||
|
|
||||||
Command path.
|
|
||||||
|
|
||||||
=item B<--command-options>
|
|
||||||
|
|
||||||
Command options (Default: '--getstatus compaction').
|
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
|
@ -30,11 +30,12 @@ use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold)
|
||||||
sub custom_status_output {
|
sub custom_status_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $msg = sprintf("Status is '%s' [State: %s], Duration: %s, Percent complete: %s%%",
|
return sprintf(
|
||||||
|
"Status is '%s' [State: %s], Duration: %s, Percent complete: %s%%",
|
||||||
$self->{result_values}->{status}, $self->{result_values}->{state},
|
$self->{result_values}->{status}, $self->{result_values}->{state},
|
||||||
centreon::plugins::misc::change_seconds(value => $self->{result_values}->{duration}),
|
centreon::plugins::misc::change_seconds(value => $self->{result_values}->{duration}),
|
||||||
$self->{result_values}->{percent_complete});
|
$self->{result_values}->{percent_complete}
|
||||||
return $msg;
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_status_calc {
|
sub custom_status_calc {
|
||||||
|
@ -113,20 +114,10 @@ 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 => {
|
||||||
{
|
'warning-status:s' => { name => 'warning_status', default => '%{state} !~ /Enabled/i' },
|
||||||
"hostname:s" => { name => 'hostname' },
|
'critical-status:s' => { name => 'critical_status', default => '' },
|
||||||
"ssh-option:s@" => { name => 'ssh_option' },
|
});
|
||||||
"ssh-path:s" => { name => 'ssh_path' },
|
|
||||||
"ssh-command:s" => { name => 'ssh_command', default => 'ssh' },
|
|
||||||
"timeout:s" => { name => 'timeout', default => 30 },
|
|
||||||
"sudo" => { name => 'sudo' },
|
|
||||||
"command:s" => { name => 'command', default => 'syscli' },
|
|
||||||
"command-path:s" => { name => 'command_path' },
|
|
||||||
"command-options:s" => { name => 'command_options', default => '--list dedupnas' },
|
|
||||||
"warning-status:s" => { name => 'warning_status', default => '%{state} !~ /Enabled/i' },
|
|
||||||
"critical-status:s" => { name => 'critical_status', default => '' },
|
|
||||||
});
|
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
@ -135,25 +126,13 @@ sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::check_options(%options);
|
$self->SUPER::check_options(%options);
|
||||||
|
|
||||||
if (defined($self->{option_results}->{hostname}) && $self->{option_results}->{hostname} ne '') {
|
|
||||||
$self->{option_results}->{remote} = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
$self->change_macros(macros => ['warning_status', 'critical_status']);
|
$self->change_macros(macros => ['warning_status', 'critical_status']);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{global} = {};
|
my $stdout = $options{custom}->execute_command(command => 'syscli --list dedupnas');
|
||||||
|
|
||||||
my ($stdout, $exit_code) = centreon::plugins::misc::execute(output => $self->{output},
|
|
||||||
options => $self->{option_results},
|
|
||||||
sudo => $self->{option_results}->{sudo},
|
|
||||||
command => $self->{option_results}->{command},
|
|
||||||
command_path => $self->{option_results}->{command_path},
|
|
||||||
command_options => $self->{option_results}->{command_options},
|
|
||||||
);
|
|
||||||
# Output data:
|
# Output data:
|
||||||
# List of all deduped NAS on source:
|
# List of all deduped NAS on source:
|
||||||
# Total count = 2
|
# Total count = 2
|
||||||
|
@ -186,17 +165,18 @@ sub manage_selection {
|
||||||
# Actual data sent = 0
|
# Actual data sent = 0
|
||||||
# Average data sent = 0
|
# Average data sent = 0
|
||||||
|
|
||||||
|
$self->{global} = {};
|
||||||
my $id;
|
my $id;
|
||||||
foreach (split(/\n/, $stdout)) {
|
foreach (split(/\n/, $stdout)) {
|
||||||
$id = $1 if ($_ =~ /.*\[dedupnas\s=\s(.*)\]$/i);
|
$id = $1 if (/.*\[dedupnas\s=\s(.*)\]$/i);
|
||||||
$self->{global}->{$id}->{name} = $1 if ($_ =~ /.*NAS\sshare\sname\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{name} = $1 if (/.*NAS\sshare\sname\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
$self->{global}->{$id}->{state} = $1 if ($_ =~ /.*Replication\sstate\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{state} = $1 if (/.*Replication\sstate\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
$self->{global}->{$id}->{start_time} = $1 if ($_ =~ /.*Replication\sstart\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{start_time} = $1 if (/.*Replication\sstart\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
$self->{global}->{$id}->{completion_time} = $1 if ($_ =~ /.*Replication\scompletion\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{completion_time} = $1 if (/.*Replication\scompletion\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
$self->{global}->{$id}->{status} = $1 if ($_ =~ /.*Replication\sstatus\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{status} = $1 if (/.*Replication\sstatus\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
$self->{global}->{$id}->{percent_complete} = $1 if ($_ =~ /.*Percent\scomplete\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{percent_complete} = $1 if (/.*Percent\scomplete\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
$self->{global}->{$id}->{original_size} = $1 if ($_ =~ /.*Original\sdata\ssize\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{original_size} = $1 if (/.*Original\sdata\ssize\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
$self->{global}->{$id}->{sent_size} = $1 if ($_ =~ /.*Actual\sdata\ssent\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{sent_size} = $1 if (/.*Actual\sdata\ssent\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
$self->{global}->{$id}->{status} = "-" if (defined($id) && $id ne '' && !defined($self->{global}->{$id}->{status}));
|
$self->{global}->{$id}->{status} = "-" if (defined($id) && $id ne '' && !defined($self->{global}->{$id}->{status}));
|
||||||
$self->{global}->{$id}->{start_time} = "-" if (defined($id) && !defined($self->{global}->{$id}->{start_time}));
|
$self->{global}->{$id}->{start_time} = "-" if (defined($id) && !defined($self->{global}->{$id}->{start_time}));
|
||||||
$self->{global}->{$id}->{completion_time} = "-" if (defined($id) && !defined($self->{global}->{$id}->{completion_time}));
|
$self->{global}->{$id}->{completion_time} = "-" if (defined($id) && !defined($self->{global}->{$id}->{completion_time}));
|
||||||
|
@ -213,10 +193,6 @@ Check deduped NAS on source.
|
||||||
|
|
||||||
=over 8
|
=over 8
|
||||||
|
|
||||||
=item B<--hostname>
|
|
||||||
|
|
||||||
Hostname to query.
|
|
||||||
|
|
||||||
=item B<--filter-counters>
|
=item B<--filter-counters>
|
||||||
|
|
||||||
Only display some counters (regexp can be used).
|
Only display some counters (regexp can be used).
|
||||||
|
@ -232,48 +208,11 @@ Can used special variables like: %{status}, %{state}, %{duration}, %{percent_com
|
||||||
Set critical threshold for status (Default: '').
|
Set critical threshold for status (Default: '').
|
||||||
Can used special variables like: %{status}, %{state}, %{duration}, %{percent_complete}.
|
Can used special variables like: %{status}, %{state}, %{duration}, %{percent_complete}.
|
||||||
|
|
||||||
=item B<--warning-*>
|
=item B<--warning-*> B<--critical-*>
|
||||||
|
|
||||||
Threshold warning.
|
Thresholds.
|
||||||
Can be: 'original-data-size', 'sent-data-size'.
|
Can be: 'original-data-size', 'sent-data-size'.
|
||||||
|
|
||||||
=item B<--critical-*>
|
|
||||||
|
|
||||||
Threshold critical.
|
|
||||||
Can be: 'original-data-size', 'sent-data-size'.
|
|
||||||
|
|
||||||
=item B<--ssh-option>
|
|
||||||
|
|
||||||
Specify multiple options like the user (example: --ssh-option='-l=centreon-engine' --ssh-option='-p=52').
|
|
||||||
|
|
||||||
=item B<--ssh-path>
|
|
||||||
|
|
||||||
Specify ssh command path (default: none)
|
|
||||||
|
|
||||||
=item B<--ssh-command>
|
|
||||||
|
|
||||||
Specify ssh command (default: 'ssh'). Useful to use 'plink'.
|
|
||||||
|
|
||||||
=item B<--timeout>
|
|
||||||
|
|
||||||
Timeout in seconds for the command (Default: 30).
|
|
||||||
|
|
||||||
=item B<--sudo>
|
|
||||||
|
|
||||||
Use 'sudo' to execute the command.
|
|
||||||
|
|
||||||
=item B<--command>
|
|
||||||
|
|
||||||
Command to get information (Default: 'syscli').
|
|
||||||
|
|
||||||
=item B<--command-path>
|
|
||||||
|
|
||||||
Command path.
|
|
||||||
|
|
||||||
=item B<--command-options>
|
|
||||||
|
|
||||||
Command options (Default: '--list dedupnas').
|
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
|
@ -30,12 +30,11 @@ use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold)
|
||||||
sub custom_status_output {
|
sub custom_status_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $msg = sprintf("Status is '%s' [State: %s], Duration: %s, Percent complete: %s%%",
|
return sprintf("Status is '%s' [State: %s], Duration: %s, Percent complete: %s%%",
|
||||||
$self->{result_values}->{status}, $self->{result_values}->{state},
|
$self->{result_values}->{status}, $self->{result_values}->{state},
|
||||||
centreon::plugins::misc::change_seconds(value => $self->{result_values}->{duration}),
|
centreon::plugins::misc::change_seconds(value => $self->{result_values}->{duration}),
|
||||||
$self->{result_values}->{percent_complete}
|
$self->{result_values}->{percent_complete}
|
||||||
);
|
);
|
||||||
return $msg;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_status_calc {
|
sub custom_status_calc {
|
||||||
|
@ -78,8 +77,10 @@ sub set_counters {
|
||||||
|
|
||||||
$self->{maps_counters}->{global} = [
|
$self->{maps_counters}->{global} = [
|
||||||
{ label => 'status', threshold => 0, set => {
|
{ label => 'status', threshold => 0, set => {
|
||||||
key_values => [ { name => 'status' }, { name => 'state' }, { name => 'start_time' },
|
key_values => [
|
||||||
{ name => 'completion_time' }, { name => 'percent_complete' }, { name => 'name' } ],
|
{ name => 'status' }, { name => 'state' }, { name => 'start_time' },
|
||||||
|
{ name => 'completion_time' }, { name => 'percent_complete' }, { name => 'name' }
|
||||||
|
],
|
||||||
closure_custom_calc => $self->can('custom_status_calc'),
|
closure_custom_calc => $self->can('custom_status_calc'),
|
||||||
closure_custom_output => $self->can('custom_status_output'),
|
closure_custom_output => $self->can('custom_status_output'),
|
||||||
closure_custom_perfdata => sub { return 0; },
|
closure_custom_perfdata => sub { return 0; },
|
||||||
|
@ -115,17 +116,8 @@ sub new {
|
||||||
bless $self, $class;
|
bless $self, $class;
|
||||||
|
|
||||||
$options{options}->add_options(arguments => {
|
$options{options}->add_options(arguments => {
|
||||||
'hostname:s' => { name => 'hostname' },
|
'warning-status:s' => { name => 'warning_status', default => '%{state} !~ /Enabled/i' },
|
||||||
'ssh-option:s@' => { name => 'ssh_option' },
|
'critical-status:s' => { name => 'critical_status', default => '' },
|
||||||
'ssh-path:s' => { name => 'ssh_path' },
|
|
||||||
'ssh-command:s' => { name => 'ssh_command', default => 'ssh' },
|
|
||||||
'timeout:s' => { name => 'timeout', default => 30 },
|
|
||||||
'sudo' => { name => 'sudo' },
|
|
||||||
'command:s' => { name => 'command', default => 'syscli' },
|
|
||||||
'command-path:s' => { name => 'command_path' },
|
|
||||||
'command-options:s' => { name => 'command_options', default => '--list dedupvtl' },
|
|
||||||
'warning-status:s' => { name => 'warning_status', default => '%{state} !~ /Enabled/i' },
|
|
||||||
'critical-status:s' => { name => 'critical_status', default => '' },
|
|
||||||
});
|
});
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
|
@ -135,26 +127,13 @@ sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::check_options(%options);
|
$self->SUPER::check_options(%options);
|
||||||
|
|
||||||
if (defined($self->{option_results}->{hostname}) && $self->{option_results}->{hostname} ne '') {
|
|
||||||
$self->{option_results}->{remote} = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
$self->change_macros(macros => ['warning_status', 'critical_status']);
|
$self->change_macros(macros => ['warning_status', 'critical_status']);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{global} = {};
|
my $stdout = $options{custom}->execute_command(command => 'syscli --list dedupvtl');
|
||||||
|
|
||||||
my ($stdout, $exit_code) = centreon::plugins::misc::execute(
|
|
||||||
output => $self->{output},
|
|
||||||
options => $self->{option_results},
|
|
||||||
sudo => $self->{option_results}->{sudo},
|
|
||||||
command => $self->{option_results}->{command},
|
|
||||||
command_path => $self->{option_results}->{command_path},
|
|
||||||
command_options => $self->{option_results}->{command_options},
|
|
||||||
);
|
|
||||||
# Output data:
|
# Output data:
|
||||||
# List of all deduped VTL on source:
|
# List of all deduped VTL on source:
|
||||||
# Total count = 2
|
# Total count = 2
|
||||||
|
@ -187,17 +166,18 @@ sub manage_selection {
|
||||||
# Actual data sent = 4352486416
|
# Actual data sent = 4352486416
|
||||||
# Average data sent = 1.9672e+07
|
# Average data sent = 1.9672e+07
|
||||||
|
|
||||||
|
$self->{global} = {};
|
||||||
my $id;
|
my $id;
|
||||||
foreach (split(/\n/, $stdout)) {
|
foreach (split(/\n/, $stdout)) {
|
||||||
$id = $1 if ($_ =~ /.*\[dedupvtl\s=\s(.*)\]$/i);
|
$id = $1 if (/.*\[dedupvtl\s=\s(.*)\]$/i);
|
||||||
$self->{global}->{$id}->{name} = $1 if ($_ =~ /.*VTL\sname\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{name} = $1 if (/.*VTL\sname\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
$self->{global}->{$id}->{state} = $1 if ($_ =~ /.*Replication\sstate\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{state} = $1 if (/.*Replication\sstate\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
$self->{global}->{$id}->{start_time} = $1 if ($_ =~ /.*Replication\sstart\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{start_time} = $1 if (/.*Replication\sstart\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
$self->{global}->{$id}->{completion_time} = $1 if ($_ =~ /.*Replication\scompletion\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{completion_time} = $1 if (/.*Replication\scompletion\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
$self->{global}->{$id}->{status} = $1 if ($_ =~ /.*Replication\sstatus\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{status} = $1 if (/.*Replication\sstatus\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
$self->{global}->{$id}->{percent_complete} = $1 if ($_ =~ /.*Percent\scomplete\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{percent_complete} = $1 if (/.*Percent\scomplete\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
$self->{global}->{$id}->{original_size} = $1 if ($_ =~ /.*Original\sdata\ssize\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{original_size} = $1 if (/.*Original\sdata\ssize\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
$self->{global}->{$id}->{sent_size} = $1 if ($_ =~ /.*Actual\sdata\ssent\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{sent_size} = $1 if (/.*Actual\sdata\ssent\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
$self->{global}->{$id}->{status} = "-" if (defined($id) && $id ne '' && !defined($self->{global}->{$id}->{status}));
|
$self->{global}->{$id}->{status} = "-" if (defined($id) && $id ne '' && !defined($self->{global}->{$id}->{status}));
|
||||||
$self->{global}->{$id}->{start_time} = "-" if (defined($id) && !defined($self->{global}->{$id}->{start_time}));
|
$self->{global}->{$id}->{start_time} = "-" if (defined($id) && !defined($self->{global}->{$id}->{start_time}));
|
||||||
$self->{global}->{$id}->{completion_time} = "-" if (defined($id) && !defined($self->{global}->{$id}->{completion_time}));
|
$self->{global}->{$id}->{completion_time} = "-" if (defined($id) && !defined($self->{global}->{$id}->{completion_time}));
|
||||||
|
@ -214,10 +194,6 @@ Check deduped VTL on source.
|
||||||
|
|
||||||
=over 8
|
=over 8
|
||||||
|
|
||||||
=item B<--hostname>
|
|
||||||
|
|
||||||
Hostname to query.
|
|
||||||
|
|
||||||
=item B<--filter-counters>
|
=item B<--filter-counters>
|
||||||
|
|
||||||
Only display some counters (regexp can be used).
|
Only display some counters (regexp can be used).
|
||||||
|
@ -233,48 +209,11 @@ Can used special variables like: %{status}, %{state}, %{duration}, %{percent_com
|
||||||
Set critical threshold for status (Default: '').
|
Set critical threshold for status (Default: '').
|
||||||
Can used special variables like: %{status}, %{state}, %{duration}, %{percent_complete}.
|
Can used special variables like: %{status}, %{state}, %{duration}, %{percent_complete}.
|
||||||
|
|
||||||
=item B<--warning-*>
|
=item B<--warning-*> B<--critical-*>
|
||||||
|
|
||||||
Threshold warning.
|
Thresholds.
|
||||||
Can be: 'original-data-size', 'sent-data-size'.
|
Can be: 'original-data-size', 'sent-data-size'.
|
||||||
|
|
||||||
=item B<--critical-*>
|
|
||||||
|
|
||||||
Threshold critical.
|
|
||||||
Can be: 'original-data-size', 'sent-data-size'.
|
|
||||||
|
|
||||||
=item B<--ssh-option>
|
|
||||||
|
|
||||||
Specify multiple options like the user (example: --ssh-option='-l=centreon-engine' --ssh-option='-p=52').
|
|
||||||
|
|
||||||
=item B<--ssh-path>
|
|
||||||
|
|
||||||
Specify ssh command path (default: none)
|
|
||||||
|
|
||||||
=item B<--ssh-command>
|
|
||||||
|
|
||||||
Specify ssh command (default: 'ssh'). Useful to use 'plink'.
|
|
||||||
|
|
||||||
=item B<--timeout>
|
|
||||||
|
|
||||||
Timeout in seconds for the command (Default: 30).
|
|
||||||
|
|
||||||
=item B<--sudo>
|
|
||||||
|
|
||||||
Use 'sudo' to execute the command.
|
|
||||||
|
|
||||||
=item B<--command>
|
|
||||||
|
|
||||||
Command to get information (Default: 'syscli').
|
|
||||||
|
|
||||||
=item B<--command-path>
|
|
||||||
|
|
||||||
Command path.
|
|
||||||
|
|
||||||
=item B<--command-options>
|
|
||||||
|
|
||||||
Command options (Default: '--list dedupvtl').
|
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
|
@ -28,12 +28,14 @@ use warnings;
|
||||||
sub custom_usage_perfdata {
|
sub custom_usage_perfdata {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{output}->perfdata_add(label => 'used',
|
$self->{output}->perfdata_add(
|
||||||
unit => 'B',
|
label => 'used',
|
||||||
value => $self->{result_values}->{used},
|
unit => 'B',
|
||||||
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{label}, total => $self->{result_values}->{total}, cast_int => 1),
|
value => $self->{result_values}->{used},
|
||||||
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{label}, total => $self->{result_values}->{total}, cast_int => 1),
|
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{label}, total => $self->{result_values}->{total}, cast_int => 1),
|
||||||
min => 0, max => $self->{result_values}->{total});
|
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{label}, total => $self->{result_values}->{total}, cast_int => 1),
|
||||||
|
min => 0, max => $self->{result_values}->{total}
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_usage_threshold {
|
sub custom_usage_threshold {
|
||||||
|
@ -46,9 +48,14 @@ sub custom_usage_threshold {
|
||||||
$threshold_value = $self->{result_values}->{prct_used};
|
$threshold_value = $self->{result_values}->{prct_used};
|
||||||
$threshold_value = $self->{result_values}->{prct_free} if (defined($self->{instance_mode}->{option_results}->{free}));
|
$threshold_value = $self->{result_values}->{prct_free} if (defined($self->{instance_mode}->{option_results}->{free}));
|
||||||
}
|
}
|
||||||
$exit = $self->{perfdata}->threshold_check(value => $threshold_value,
|
$exit = $self->{perfdata}->threshold_check(
|
||||||
threshold => [ { label => 'critical-' . $self->{label}, exit_litteral => 'critical' },
|
value => $threshold_value,
|
||||||
{ label => 'warning-' . $self->{label}, exit_litteral => 'warning' } ]);
|
threshold => [
|
||||||
|
{ label => 'critical-' . $self->{label}, exit_litteral => 'critical' },
|
||||||
|
{ label => 'warning-' . $self->{label}, exit_litteral => 'warning' }
|
||||||
|
]
|
||||||
|
);
|
||||||
|
|
||||||
return $exit;
|
return $exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -59,11 +66,12 @@ sub custom_usage_output {
|
||||||
my ($free_value, $free_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{free});
|
my ($free_value, $free_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{free});
|
||||||
my ($total_value, $total_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{total});
|
my ($total_value, $total_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{total});
|
||||||
|
|
||||||
my $msg = sprintf("Capacity: %s Used: %s (%.2f%%) Available: %s (%.2f%%)",
|
return sprintf(
|
||||||
$total_value . " " . $total_unit,
|
"Capacity: %s Used: %s (%.2f%%) Available: %s (%.2f%%)",
|
||||||
$used_value . " " . $used_unit, $self->{result_values}->{prct_used},
|
$total_value . " " . $total_unit,
|
||||||
$free_value . " " . $free_unit, $self->{result_values}->{prct_free});
|
$used_value . " " . $used_unit, $self->{result_values}->{prct_used},
|
||||||
return $msg;
|
$free_value . " " . $free_unit, $self->{result_values}->{prct_free}
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_usage_calc {
|
sub custom_usage_calc {
|
||||||
|
@ -88,27 +96,28 @@ sub custom_usage_calc {
|
||||||
sub custom_volume_perfdata {
|
sub custom_volume_perfdata {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{output}->perfdata_add(label => $self->{result_values}->{label}, unit => 'B',
|
$self->{output}->perfdata_add(
|
||||||
value => $self->{result_values}->{volume},
|
label => $self->{result_values}->{label}, unit => 'B',
|
||||||
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{label}),
|
value => $self->{result_values}->{volume},
|
||||||
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{label})
|
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{label}),
|
||||||
);
|
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{label})
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_volume_threshold {
|
sub custom_volume_threshold {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $exit = $self->{perfdata}->threshold_check(value => $self->{result_values}->{volume},
|
return $self->{perfdata}->threshold_check(
|
||||||
threshold => [ { label => 'critical-' . $self->{label}, exit_litteral => 'critical' }, { label => 'warning-'. $self->{label}, exit_litteral => 'warning' } ]);
|
value => $self->{result_values}->{volume},
|
||||||
return $exit;
|
threshold => [ { label => 'critical-' . $self->{label}, exit_litteral => 'critical' }, { label => 'warning-'. $self->{label}, exit_litteral => 'warning' } ]
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_volume_output {
|
sub custom_volume_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my ($volume_value, $volume_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{volume});
|
my ($volume_value, $volume_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{volume});
|
||||||
my $msg = sprintf("%s: %s %s (%.2f%%)", $self->{result_values}->{display}, $volume_value, $volume_unit, $self->{result_values}->{prct_volume});
|
return sprintf('%s: %s %s (%.2f%%)', $self->{result_values}->{display}, $volume_value, $volume_unit, $self->{result_values}->{prct_volume});
|
||||||
return $msg;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_volume_calc {
|
sub custom_volume_calc {
|
||||||
|
@ -217,43 +226,17 @@ sub new {
|
||||||
bless $self, $class;
|
bless $self, $class;
|
||||||
|
|
||||||
$options{options}->add_options(arguments => {
|
$options{options}->add_options(arguments => {
|
||||||
"hostname:s" => { name => 'hostname' },
|
'units:s' => { name => 'units', default => '%' },
|
||||||
"ssh-option:s@" => { name => 'ssh_option' },
|
'free' => { name => 'free' },
|
||||||
"ssh-path:s" => { name => 'ssh_path' },
|
|
||||||
"ssh-command:s" => { name => 'ssh_command', default => 'ssh' },
|
|
||||||
"timeout:s" => { name => 'timeout', default => 30 },
|
|
||||||
"sudo" => { name => 'sudo' },
|
|
||||||
"command:s" => { name => 'command', default => 'syscli' },
|
|
||||||
"command-path:s" => { name => 'command_path' },
|
|
||||||
"command-options:s" => { name => 'command_options', default => '--get diskusage' },
|
|
||||||
"units:s" => { name => 'units', default => '%' },
|
|
||||||
"free" => { name => 'free' },
|
|
||||||
});
|
});
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
sub check_options {
|
|
||||||
my ($self, %options) = @_;
|
|
||||||
$self->SUPER::check_options(%options);
|
|
||||||
|
|
||||||
if (defined($self->{option_results}->{hostname}) && $self->{option_results}->{hostname} ne '') {
|
|
||||||
$self->{option_results}->{remote} = 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{global} = {};
|
my $stdout = $options{custom}->execute_command(command => 'syscli --get diskusage');
|
||||||
|
|
||||||
my ($stdout, $exit_code) = centreon::plugins::misc::execute(output => $self->{output},
|
|
||||||
options => $self->{option_results},
|
|
||||||
sudo => $self->{option_results}->{sudo},
|
|
||||||
command => $self->{option_results}->{command},
|
|
||||||
command_path => $self->{option_results}->{command_path},
|
|
||||||
command_options => $self->{option_results}->{command_options},
|
|
||||||
);
|
|
||||||
# 2.2 Output data:
|
# 2.2 Output data:
|
||||||
# Disk Capacity = 16.00 TB
|
# Disk Capacity = 16.00 TB
|
||||||
# Available Disk Space = 15.66 TB
|
# Available Disk Space = 15.66 TB
|
||||||
|
@ -271,15 +254,16 @@ sub manage_selection {
|
||||||
# System Metadata = 147.83 GB 1.48%
|
# System Metadata = 147.83 GB 1.48%
|
||||||
# Data Not Intended for Deduplication = 0.00 MB 0.00%
|
# Data Not Intended for Deduplication = 0.00 MB 0.00%
|
||||||
|
|
||||||
|
$self->{global} = {};
|
||||||
foreach (split(/\n/, $stdout)) {
|
foreach (split(/\n/, $stdout)) {
|
||||||
$self->{global}->{disk_capacity} = $1 if ($_ =~ /.*Disk\sCapacity\s=\s(.*)$/i);
|
$self->{global}->{disk_capacity} = $1 if (/.*Disk\sCapacity\s=\s(.*)$/i);
|
||||||
$self->{global}->{available_disk_space} = $1 if ($_ =~ /.*Available\sDisk\sSpace\s=\s(.*)$/i);
|
$self->{global}->{available_disk_space} = $1 if (/.*Available\sDisk\sSpace\s=\s(.*)$/i);
|
||||||
$self->{global}->{free_space} = $1 if ($_ =~ /.*Free\sSpace\s=\s(.*)\s+.*%.*$/i);
|
$self->{global}->{free_space} = $1 if (/.*Free\sSpace\s=\s(.*)\s+.*%.*$/i);
|
||||||
$self->{global}->{reclaimable_space} = $1 if ($_ =~ /.*Reclaimable\sSpace\s=\s(.*)\s+.*%.*$/i);
|
$self->{global}->{reclaimable_space} = $1 if (/.*Reclaimable\sSpace\s=\s(.*)\s+.*%.*$/i);
|
||||||
$self->{global}->{used_disk_space} = $1 if ($_ =~ /.*Used\sDisk\sSpace\s=\s(.*)$/i);
|
$self->{global}->{used_disk_space} = $1 if (/.*Used\sDisk\sSpace\s=\s(.*)$/i);
|
||||||
$self->{global}->{deduplicated_data} = $1 if ($_ =~ /.*Deduplicated\sData\s=\s(.*)\s+.*%.*$/i);
|
$self->{global}->{deduplicated_data} = $1 if (/.*Deduplicated\sData\s=\s(.*)\s+.*%.*$/i);
|
||||||
$self->{global}->{system_metadata} = $1 if ($_ =~ /.*System\sMetadata\s=\s(.*)\s+.*%.*$/i);
|
$self->{global}->{system_metadata} = $1 if (/.*System\sMetadata\s=\s(.*)\s+.*%.*$/i);
|
||||||
$self->{global}->{data_not_intended_for_deduplication} = $1 if ($_ =~ /.*Data\sNot\sIntended\sfor\sDeduplication\s=\s(.*)\s+.*%.*$/i);
|
$self->{global}->{data_not_intended_for_deduplication} = $1 if (/.*Data\sNot\sIntended\sfor\sDeduplication\s=\s(.*)\s+.*%.*$/i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -293,58 +277,16 @@ Check disk usage.
|
||||||
|
|
||||||
=over 8
|
=over 8
|
||||||
|
|
||||||
=item B<--hostname>
|
|
||||||
|
|
||||||
Hostname to query.
|
|
||||||
|
|
||||||
=item B<--filter-counters>
|
=item B<--filter-counters>
|
||||||
|
|
||||||
Only display some counters (regexp can be used).
|
Only display some counters (regexp can be used).
|
||||||
Example: --filter-counters='usage'
|
Example: --filter-counters='usage'
|
||||||
|
|
||||||
=item B<--warning-*>
|
=item B<--warning-*> B<--critical-*>
|
||||||
|
|
||||||
Threshold warning.
|
Thresholds.
|
||||||
Can be: 'usage', 'free-space','reclaimable-space', 'deduplicated-data',
|
Can be: 'usage', 'free-space','reclaimable-space', 'deduplicated-data',
|
||||||
'system-metadata', 'data-not-intended-for-deduplication'
|
'system-metadata', 'data-not-intended-for-deduplication'.
|
||||||
|
|
||||||
=item B<--critical-*>
|
|
||||||
|
|
||||||
Threshold critical.
|
|
||||||
Can be: 'usage', 'free-space','reclaimable-space', 'deduplicated-data',
|
|
||||||
'system-metadata', 'data-not-intended-for-deduplication'
|
|
||||||
|
|
||||||
=item B<--ssh-option>
|
|
||||||
|
|
||||||
Specify multiple options like the user (example: --ssh-option='-l=centreon-engine' --ssh-option='-p=52').
|
|
||||||
|
|
||||||
=item B<--ssh-path>
|
|
||||||
|
|
||||||
Specify ssh command path (default: none)
|
|
||||||
|
|
||||||
=item B<--ssh-command>
|
|
||||||
|
|
||||||
Specify ssh command (default: 'ssh'). Useful to use 'plink'.
|
|
||||||
|
|
||||||
=item B<--timeout>
|
|
||||||
|
|
||||||
Timeout in seconds for the command (Default: 30).
|
|
||||||
|
|
||||||
=item B<--sudo>
|
|
||||||
|
|
||||||
Use 'sudo' to execute the command.
|
|
||||||
|
|
||||||
=item B<--command>
|
|
||||||
|
|
||||||
Command to get information (Default: 'syscli').
|
|
||||||
|
|
||||||
=item B<--command-path>
|
|
||||||
|
|
||||||
Command path.
|
|
||||||
|
|
||||||
=item B<--command-options>
|
|
||||||
|
|
||||||
Command options (Default: '--get diskusage').
|
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
|
|
|
@ -29,8 +29,7 @@ use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold)
|
||||||
sub custom_status_output {
|
sub custom_status_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $msg = "status is '" . $self->{result_values}->{status} . "' [state = " . $self->{result_values}->{state} . "]";
|
return "status is '" . $self->{result_values}->{status} . "' [state = " . $self->{result_values}->{state} . "]";
|
||||||
return $msg;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_status_calc {
|
sub custom_status_calc {
|
||||||
|
@ -72,20 +71,10 @@ 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 => {
|
||||||
{
|
'warning-status:s' => { name => 'warning_status' },
|
||||||
"hostname:s" => { name => 'hostname' },
|
'critical-status:s' => { name => 'critical_status', default => '%{status} !~ /Ready|Success/i' },
|
||||||
"ssh-option:s@" => { name => 'ssh_option' },
|
});
|
||||||
"ssh-path:s" => { name => 'ssh_path' },
|
|
||||||
"ssh-command:s" => { name => 'ssh_command', default => 'ssh' },
|
|
||||||
"timeout:s" => { name => 'timeout', default => 30 },
|
|
||||||
"sudo" => { name => 'sudo' },
|
|
||||||
"command:s" => { name => 'command', default => 'syscli' },
|
|
||||||
"command-path:s" => { name => 'command_path' },
|
|
||||||
"command-options:s" => { name => 'command_options', default => '--list healthcheckstatus' },
|
|
||||||
"warning-status:s" => { name => 'warning_status' },
|
|
||||||
"critical-status:s" => { name => 'critical_status', default => '%{status} !~ /Ready|Success/i' },
|
|
||||||
});
|
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
@ -94,25 +83,13 @@ sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::check_options(%options);
|
$self->SUPER::check_options(%options);
|
||||||
|
|
||||||
if (defined($self->{option_results}->{hostname}) && $self->{option_results}->{hostname} ne '') {
|
|
||||||
$self->{option_results}->{remote} = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
$self->change_macros(macros => ['warning_status', 'critical_status']);
|
$self->change_macros(macros => ['warning_status', 'critical_status']);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{global} = {};
|
my $stdout = $options{custom}->execute_command(command => 'syscli --list healthcheckstatus');
|
||||||
|
|
||||||
my ($stdout, $exit_code) = centreon::plugins::misc::execute(output => $self->{output},
|
|
||||||
options => $self->{option_results},
|
|
||||||
sudo => $self->{option_results}->{sudo},
|
|
||||||
command => $self->{option_results}->{command},
|
|
||||||
command_path => $self->{option_results}->{command_path},
|
|
||||||
command_options => $self->{option_results}->{command_options},
|
|
||||||
);
|
|
||||||
# Output data:
|
# Output data:
|
||||||
# Healthcheck Status
|
# Healthcheck Status
|
||||||
# Total count = 2
|
# Total count = 2
|
||||||
|
@ -129,12 +106,13 @@ sub manage_selection {
|
||||||
# Finished =
|
# Finished =
|
||||||
# Status = Ready
|
# Status = Ready
|
||||||
|
|
||||||
|
$self->{global} = {};
|
||||||
my $id;
|
my $id;
|
||||||
foreach (split(/\n/, $stdout)) {
|
foreach (split(/\n/, $stdout)) {
|
||||||
$id = $1 if ($_ =~ /.*\[HealthCheck\s=\s(.*)\]$/i);
|
$id = $1 if (/.*\[HealthCheck\s=\s(.*)\]$/i);
|
||||||
$self->{global}->{$id}->{status} = $1 if ($_ =~ /.*Status\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{status} = $1 if (/.*Status\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
$self->{global}->{$id}->{state} = $1 if ($_ =~ /.*State\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{state} = $1 if (/.*State\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
$self->{global}->{$id}->{name} = $1 if ($_ =~ /.*Healthcheck\sName\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{name} = $1 if (/.*Healthcheck\sName\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -148,10 +126,6 @@ Check health status.
|
||||||
|
|
||||||
=over 8
|
=over 8
|
||||||
|
|
||||||
=item B<--hostname>
|
|
||||||
|
|
||||||
Hostname to query.
|
|
||||||
|
|
||||||
=item B<--warning-status>
|
=item B<--warning-status>
|
||||||
|
|
||||||
Set warning threshold for status (Default: '').
|
Set warning threshold for status (Default: '').
|
||||||
|
@ -162,38 +136,6 @@ Can used special variables like: %{name}, %{status}, %{state}
|
||||||
Set critical threshold for status (Default: '%{status} !~ /Ready|Success/i').
|
Set critical threshold for status (Default: '%{status} !~ /Ready|Success/i').
|
||||||
Can used special variables like: %{name}, %{status}, %{state}
|
Can used special variables like: %{name}, %{status}, %{state}
|
||||||
|
|
||||||
=item B<--ssh-option>
|
|
||||||
|
|
||||||
Specify multiple options like the user (example: --ssh-option='-l=centreon-engine' --ssh-option='-p=52').
|
|
||||||
|
|
||||||
=item B<--ssh-path>
|
|
||||||
|
|
||||||
Specify ssh command path (default: none)
|
|
||||||
|
|
||||||
=item B<--ssh-command>
|
|
||||||
|
|
||||||
Specify ssh command (default: 'ssh'). Useful to use 'plink'.
|
|
||||||
|
|
||||||
=item B<--timeout>
|
|
||||||
|
|
||||||
Timeout in seconds for the command (Default: 30).
|
|
||||||
|
|
||||||
=item B<--sudo>
|
|
||||||
|
|
||||||
Use 'sudo' to execute the command.
|
|
||||||
|
|
||||||
=item B<--command>
|
|
||||||
|
|
||||||
Command to get information (Default: 'syscli').
|
|
||||||
|
|
||||||
=item B<--command-path>
|
|
||||||
|
|
||||||
Command path.
|
|
||||||
|
|
||||||
=item B<--command-options>
|
|
||||||
|
|
||||||
Command options (Default: '--list healthcheckstatus').
|
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
|
@ -29,8 +29,7 @@ use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold)
|
||||||
sub custom_status_output {
|
sub custom_status_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $msg = "status is '" . $self->{result_values}->{status} . "'";
|
return "status is '" . $self->{result_values}->{status} . "'";
|
||||||
return $msg;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_status_calc {
|
sub custom_status_calc {
|
||||||
|
@ -71,20 +70,10 @@ 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 => {
|
||||||
{
|
'warning-status:s' => { name => 'warning_status' },
|
||||||
"hostname:s" => { name => 'hostname' },
|
'critical-status:s' => { name => 'critical_status', default => '%{status} !~ /Normal/i' },
|
||||||
"ssh-option:s@" => { name => 'ssh_option' },
|
});
|
||||||
"ssh-path:s" => { name => 'ssh_path' },
|
|
||||||
"ssh-command:s" => { name => 'ssh_command', default => 'ssh' },
|
|
||||||
"timeout:s" => { name => 'timeout', default => 30 },
|
|
||||||
"sudo" => { name => 'sudo' },
|
|
||||||
"command:s" => { name => 'command', default => 'syscli' },
|
|
||||||
"command-path:s" => { name => 'command_path' },
|
|
||||||
"command-options:s" => { name => 'command_options', default => '--getstatus hostbusadapter' },
|
|
||||||
"warning-status:s" => { name => 'warning_status' },
|
|
||||||
"critical-status:s" => { name => 'critical_status', default => '%{status} !~ /Normal/i' },
|
|
||||||
});
|
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
@ -93,25 +82,13 @@ sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::check_options(%options);
|
$self->SUPER::check_options(%options);
|
||||||
|
|
||||||
if (defined($self->{option_results}->{hostname}) && $self->{option_results}->{hostname} ne '') {
|
|
||||||
$self->{option_results}->{remote} = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
$self->change_macros(macros => ['warning_status', 'critical_status']);
|
$self->change_macros(macros => ['warning_status', 'critical_status']);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{global} = {};
|
my $stdout = $options{custom}->execute_command(command => 'syscli --getstatus hostbusadapter');
|
||||||
|
|
||||||
my ($stdout, $exit_code) = centreon::plugins::misc::execute(output => $self->{output},
|
|
||||||
options => $self->{option_results},
|
|
||||||
sudo => $self->{option_results}->{sudo},
|
|
||||||
command => $self->{option_results}->{command},
|
|
||||||
command_path => $self->{option_results}->{command_path},
|
|
||||||
command_options => $self->{option_results}->{command_options},
|
|
||||||
);
|
|
||||||
# Output data:
|
# Output data:
|
||||||
# List of Hostbus Adapters
|
# List of Hostbus Adapters
|
||||||
# Total count = 4
|
# Total count = 4
|
||||||
|
@ -128,11 +105,12 @@ sub manage_selection {
|
||||||
# Name = SAS HBA 2
|
# Name = SAS HBA 2
|
||||||
# Status = Normal
|
# Status = Normal
|
||||||
|
|
||||||
|
$self->{global} = {};
|
||||||
my $id;
|
my $id;
|
||||||
foreach (split(/\n/, $stdout)) {
|
foreach (split(/\n/, $stdout)) {
|
||||||
$id = $1 if ($_ =~ /.*\[Hostbus\sAdapter\s=\s(.*)\]$/i);
|
$id = $1 if (/.*\[Hostbus\sAdapter\s=\s(.*)\]$/i);
|
||||||
$self->{global}->{$id}->{status} = $1 if ($_ =~ /.*Status\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{status} = $1 if (/.*Status\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
$self->{global}->{$id}->{name} = $1 if ($_ =~ /.*Name\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{name} = $1 if (/.*Name\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -146,10 +124,6 @@ Check hostbus adapters status.
|
||||||
|
|
||||||
=over 8
|
=over 8
|
||||||
|
|
||||||
=item B<--hostname>
|
|
||||||
|
|
||||||
Hostname to query.
|
|
||||||
|
|
||||||
=item B<--warning-status>
|
=item B<--warning-status>
|
||||||
|
|
||||||
Set warning threshold for status (Default: '').
|
Set warning threshold for status (Default: '').
|
||||||
|
@ -160,38 +134,6 @@ Can used special variables like: %{name}, %{status}
|
||||||
Set critical threshold for status (Default: '%{status} !~ /Normal/i').
|
Set critical threshold for status (Default: '%{status} !~ /Normal/i').
|
||||||
Can used special variables like: %{name}, %{status}
|
Can used special variables like: %{name}, %{status}
|
||||||
|
|
||||||
=item B<--ssh-option>
|
|
||||||
|
|
||||||
Specify multiple options like the user (example: --ssh-option='-l=centreon-engine' --ssh-option='-p=52').
|
|
||||||
|
|
||||||
=item B<--ssh-path>
|
|
||||||
|
|
||||||
Specify ssh command path (default: none)
|
|
||||||
|
|
||||||
=item B<--ssh-command>
|
|
||||||
|
|
||||||
Specify ssh command (default: 'ssh'). Useful to use 'plink'.
|
|
||||||
|
|
||||||
=item B<--timeout>
|
|
||||||
|
|
||||||
Timeout in seconds for the command (Default: 30).
|
|
||||||
|
|
||||||
=item B<--sudo>
|
|
||||||
|
|
||||||
Use 'sudo' to execute the command.
|
|
||||||
|
|
||||||
=item B<--command>
|
|
||||||
|
|
||||||
Command to get information (Default: 'syscli').
|
|
||||||
|
|
||||||
=item B<--command-path>
|
|
||||||
|
|
||||||
Command path.
|
|
||||||
|
|
||||||
=item B<--command-options>
|
|
||||||
|
|
||||||
Command options (Default: '--getstatus hostbusadapter').
|
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
|
@ -28,12 +28,14 @@ use warnings;
|
||||||
sub custom_usage_perfdata {
|
sub custom_usage_perfdata {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{output}->perfdata_add(label => 'used',
|
$self->{output}->perfdata_add(
|
||||||
unit => 'B',
|
label => 'used',
|
||||||
value => $self->{result_values}->{used},
|
unit => 'B',
|
||||||
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{label}, total => $self->{result_values}->{total}, cast_int => 1),
|
value => $self->{result_values}->{used},
|
||||||
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{label}, total => $self->{result_values}->{total}, cast_int => 1),
|
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{label}, total => $self->{result_values}->{total}, cast_int => 1),
|
||||||
min => 0, max => $self->{result_values}->{total});
|
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{label}, total => $self->{result_values}->{total}, cast_int => 1),
|
||||||
|
min => 0, max => $self->{result_values}->{total}
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_usage_threshold {
|
sub custom_usage_threshold {
|
||||||
|
@ -46,9 +48,13 @@ sub custom_usage_threshold {
|
||||||
$threshold_value = $self->{result_values}->{prct_used};
|
$threshold_value = $self->{result_values}->{prct_used};
|
||||||
$threshold_value = $self->{result_values}->{prct_free} if (defined($self->{instance_mode}->{option_results}->{free}));
|
$threshold_value = $self->{result_values}->{prct_free} if (defined($self->{instance_mode}->{option_results}->{free}));
|
||||||
}
|
}
|
||||||
$exit = $self->{perfdata}->threshold_check(value => $threshold_value,
|
$exit = $self->{perfdata}->threshold_check(
|
||||||
threshold => [ { label => 'critical-' . $self->{label}, exit_litteral => 'critical' },
|
value => $threshold_value,
|
||||||
{ label => 'warning-' . $self->{label}, exit_litteral => 'warning' } ]);
|
threshold => [
|
||||||
|
{ label => 'critical-' . $self->{label}, exit_litteral => 'critical' },
|
||||||
|
{ label => 'warning-' . $self->{label}, exit_litteral => 'warning' }
|
||||||
|
]
|
||||||
|
);
|
||||||
return $exit;
|
return $exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -59,11 +65,12 @@ sub custom_usage_output {
|
||||||
my ($free_value, $free_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{free});
|
my ($free_value, $free_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{free});
|
||||||
my ($total_value, $total_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{total});
|
my ($total_value, $total_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{total});
|
||||||
|
|
||||||
my $msg = sprintf("Total: %s Used: %s (%.2f%%) Free: %s (%.2f%%)",
|
return sprintf(
|
||||||
$total_value . " " . $total_unit,
|
"Total: %s Used: %s (%.2f%%) Free: %s (%.2f%%)",
|
||||||
$used_value . " " . $used_unit, $self->{result_values}->{prct_used},
|
$total_value . " " . $total_unit,
|
||||||
$free_value . " " . $free_unit, $self->{result_values}->{prct_free});
|
$used_value . " " . $used_unit, $self->{result_values}->{prct_used},
|
||||||
return $msg;
|
$free_value . " " . $free_unit, $self->{result_values}->{prct_free}
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_usage_calc {
|
sub custom_usage_calc {
|
||||||
|
@ -127,50 +134,25 @@ sub new {
|
||||||
bless $self, $class;
|
bless $self, $class;
|
||||||
|
|
||||||
$options{options}->add_options(arguments => {
|
$options{options}->add_options(arguments => {
|
||||||
"hostname:s" => { name => 'hostname' },
|
'units:s' => { name => 'units', default => '%' },
|
||||||
"ssh-option:s@" => { name => 'ssh_option' },
|
'free' => { name => 'free' },
|
||||||
"ssh-path:s" => { name => 'ssh_path' },
|
|
||||||
"ssh-command:s" => { name => 'ssh_command', default => 'ssh' },
|
|
||||||
"timeout:s" => { name => 'timeout', default => 30 },
|
|
||||||
"sudo" => { name => 'sudo' },
|
|
||||||
"command:s" => { name => 'command', default => 'syscli' },
|
|
||||||
"command-path:s" => { name => 'command_path' },
|
|
||||||
"command-options:s" => { name => 'command_options', default => '--getstatus systemmemory' },
|
|
||||||
"units:s" => { name => 'units', default => '%' },
|
|
||||||
"free" => { name => 'free' },
|
|
||||||
});
|
});
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
sub check_options {
|
|
||||||
my ($self, %options) = @_;
|
|
||||||
$self->SUPER::check_options(%options);
|
|
||||||
|
|
||||||
if (defined($self->{option_results}->{hostname}) && $self->{option_results}->{hostname} ne '') {
|
|
||||||
$self->{option_results}->{remote} = 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{global} = {};
|
my $stdout = $options{custom}->execute_command(command => 'syscli --getstatus systemmemory');
|
||||||
|
|
||||||
my ($stdout, $exit_code) = centreon::plugins::misc::execute(output => $self->{output},
|
|
||||||
options => $self->{option_results},
|
|
||||||
sudo => $self->{option_results}->{sudo},
|
|
||||||
command => $self->{option_results}->{command},
|
|
||||||
command_path => $self->{option_results}->{command_path},
|
|
||||||
command_options => $self->{option_results}->{command_options},
|
|
||||||
);
|
|
||||||
# Output data:
|
# Output data:
|
||||||
# Total Memory = 270.76 GB
|
# Total Memory = 270.76 GB
|
||||||
# Free Memory = 91.19 GB
|
# Free Memory = 91.19 GB
|
||||||
|
|
||||||
|
$self->{global} = {};
|
||||||
foreach (split(/\n/, $stdout)) {
|
foreach (split(/\n/, $stdout)) {
|
||||||
$self->{global}->{total} = $1 if ($_ =~ /.*Total\sMemory\s=\s(.*)$/i);
|
$self->{global}->{total} = $1 if (/.*Total\sMemory\s=\s(.*)$/i);
|
||||||
$self->{global}->{free} = $1 if ($_ =~ /.*Free\sMemory\s=\s(.*)$/i);
|
$self->{global}->{free} = $1 if (/.*Free\sMemory\s=\s(.*)$/i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -184,10 +166,6 @@ Check memory usage.
|
||||||
|
|
||||||
=over 8
|
=over 8
|
||||||
|
|
||||||
=item B<--hostname>
|
|
||||||
|
|
||||||
Hostname to query.
|
|
||||||
|
|
||||||
=item B<--warning-usage>
|
=item B<--warning-usage>
|
||||||
|
|
||||||
Threshold warning.
|
Threshold warning.
|
||||||
|
@ -196,38 +174,6 @@ Threshold warning.
|
||||||
|
|
||||||
Threshold critical.
|
Threshold critical.
|
||||||
|
|
||||||
=item B<--ssh-option>
|
|
||||||
|
|
||||||
Specify multiple options like the user (example: --ssh-option='-l=centreon-engine' --ssh-option='-p=52').
|
|
||||||
|
|
||||||
=item B<--ssh-path>
|
|
||||||
|
|
||||||
Specify ssh command path (default: none)
|
|
||||||
|
|
||||||
=item B<--ssh-command>
|
|
||||||
|
|
||||||
Specify ssh command (default: 'ssh'). Useful to use 'plink'.
|
|
||||||
|
|
||||||
=item B<--timeout>
|
|
||||||
|
|
||||||
Timeout in seconds for the command (Default: 30).
|
|
||||||
|
|
||||||
=item B<--sudo>
|
|
||||||
|
|
||||||
Use 'sudo' to execute the command.
|
|
||||||
|
|
||||||
=item B<--command>
|
|
||||||
|
|
||||||
Command to get information (Default: 'syscli').
|
|
||||||
|
|
||||||
=item B<--command-path>
|
|
||||||
|
|
||||||
Command path.
|
|
||||||
|
|
||||||
=item B<--command-options>
|
|
||||||
|
|
||||||
Command options (Default: '--getstatus systemmemory').
|
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
|
@ -29,8 +29,7 @@ use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold)
|
||||||
sub custom_status_output {
|
sub custom_status_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $msg = "status is '" . $self->{result_values}->{status} . "' [value = " . $self->{result_values}->{value} . "]";
|
return "status is '" . $self->{result_values}->{status} . "' [value = " . $self->{result_values}->{value} . "]";
|
||||||
return $msg;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_status_calc {
|
sub custom_status_calc {
|
||||||
|
@ -72,20 +71,10 @@ 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 => {
|
||||||
{
|
'warning-status:s' => { name => 'warning_status' },
|
||||||
"hostname:s" => { name => 'hostname' },
|
'critical-status:s' => { name => 'critical_status', default => '%{status} !~ /Up/i' },
|
||||||
"ssh-option:s@" => { name => 'ssh_option' },
|
});
|
||||||
"ssh-path:s" => { name => 'ssh_path' },
|
|
||||||
"ssh-command:s" => { name => 'ssh_command', default => 'ssh' },
|
|
||||||
"timeout:s" => { name => 'timeout', default => 30 },
|
|
||||||
"sudo" => { name => 'sudo' },
|
|
||||||
"command:s" => { name => 'command', default => 'syscli' },
|
|
||||||
"command-path:s" => { name => 'command_path' },
|
|
||||||
"command-options:s" => { name => 'command_options', default => '--getstatus networkport' },
|
|
||||||
"warning-status:s" => { name => 'warning_status' },
|
|
||||||
"critical-status:s" => { name => 'critical_status', default => '%{status} !~ /Up/i' },
|
|
||||||
});
|
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
@ -94,25 +83,13 @@ sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::check_options(%options);
|
$self->SUPER::check_options(%options);
|
||||||
|
|
||||||
if (defined($self->{option_results}->{hostname}) && $self->{option_results}->{hostname} ne '') {
|
|
||||||
$self->{option_results}->{remote} = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
$self->change_macros(macros => ['warning_status', 'critical_status']);
|
$self->change_macros(macros => ['warning_status', 'critical_status']);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{global} = {};
|
my $stdout = $options{custom}->execute_command(command => 'syscli --getstatus networkport');
|
||||||
|
|
||||||
my ($stdout, $exit_code) = centreon::plugins::misc::execute(output => $self->{output},
|
|
||||||
options => $self->{option_results},
|
|
||||||
sudo => $self->{option_results}->{sudo},
|
|
||||||
command => $self->{option_results}->{command},
|
|
||||||
command_path => $self->{option_results}->{command_path},
|
|
||||||
command_options => $self->{option_results}->{command_options},
|
|
||||||
);
|
|
||||||
# Output data:
|
# Output data:
|
||||||
# Network Ports
|
# Network Ports
|
||||||
# Total count = 5
|
# Total count = 5
|
||||||
|
@ -129,12 +106,13 @@ sub manage_selection {
|
||||||
# Value = NA
|
# Value = NA
|
||||||
# Status = Down
|
# Status = Down
|
||||||
|
|
||||||
|
$self->{global} = {};
|
||||||
my $id;
|
my $id;
|
||||||
foreach (split(/\n/, $stdout)) {
|
foreach (split(/\n/, $stdout)) {
|
||||||
$id = $1 if ($_ =~ /.*\[Port\s=\s(.*)\]$/i);
|
$id = $1 if (/.*\[Port\s=\s(.*)\]$/i);
|
||||||
$self->{global}->{$id}->{status} = $1 if ($_ =~ /.*Status\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{status} = $1 if (/.*Status\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
$self->{global}->{$id}->{name} = $1 if ($_ =~ /.*Name\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{name} = $1 if (/.*Name\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
$self->{global}->{$id}->{value} = $1 if ($_ =~ /.*Value\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{value} = $1 if (/.*Value\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -148,10 +126,6 @@ Check network ports status.
|
||||||
|
|
||||||
=over 8
|
=over 8
|
||||||
|
|
||||||
=item B<--hostname>
|
|
||||||
|
|
||||||
Hostname to query.
|
|
||||||
|
|
||||||
=item B<--warning-status>
|
=item B<--warning-status>
|
||||||
|
|
||||||
Set warning threshold for status (Default: '').
|
Set warning threshold for status (Default: '').
|
||||||
|
@ -162,38 +136,6 @@ Can used special variables like: %{name}, %{status}
|
||||||
Set critical threshold for status (Default: '%{status} !~ /Up/i').
|
Set critical threshold for status (Default: '%{status} !~ /Up/i').
|
||||||
Can used special variables like: %{name}, %{status}
|
Can used special variables like: %{name}, %{status}
|
||||||
|
|
||||||
=item B<--ssh-option>
|
|
||||||
|
|
||||||
Specify multiple options like the user (example: --ssh-option='-l=centreon-engine' --ssh-option='-p=52').
|
|
||||||
|
|
||||||
=item B<--ssh-path>
|
|
||||||
|
|
||||||
Specify ssh command path (default: none)
|
|
||||||
|
|
||||||
=item B<--ssh-command>
|
|
||||||
|
|
||||||
Specify ssh command (default: 'ssh'). Useful to use 'plink'.
|
|
||||||
|
|
||||||
=item B<--timeout>
|
|
||||||
|
|
||||||
Timeout in seconds for the command (Default: 30).
|
|
||||||
|
|
||||||
=item B<--sudo>
|
|
||||||
|
|
||||||
Use 'sudo' to execute the command.
|
|
||||||
|
|
||||||
=item B<--command>
|
|
||||||
|
|
||||||
Command to get information (Default: 'syscli').
|
|
||||||
|
|
||||||
=item B<--command-path>
|
|
||||||
|
|
||||||
Command path.
|
|
||||||
|
|
||||||
=item B<--command-options>
|
|
||||||
|
|
||||||
Command options (Default: '--getstatus networkport').
|
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
|
@ -29,8 +29,7 @@ use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold)
|
||||||
sub custom_status_output {
|
sub custom_status_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $msg = 'Reclamation status: ' . $self->{result_values}->{reclamation_status};
|
return 'Reclamation status: ' . $self->{result_values}->{reclamation_status};
|
||||||
return $msg;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_status_calc {
|
sub custom_status_calc {
|
||||||
|
@ -43,18 +42,21 @@ sub custom_status_calc {
|
||||||
sub custom_volume_perfdata {
|
sub custom_volume_perfdata {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{output}->perfdata_add(label => $self->{result_values}->{label}, unit => 'B',
|
$self->{output}->perfdata_add(
|
||||||
value => $self->{result_values}->{volume},
|
label => $self->{result_values}->{label}, unit => 'B',
|
||||||
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{label}),
|
value => $self->{result_values}->{volume},
|
||||||
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{label})
|
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{label}),
|
||||||
);
|
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{label})
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_volume_threshold {
|
sub custom_volume_threshold {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $exit = $self->{perfdata}->threshold_check(value => $self->{result_values}->{volume},
|
my $exit = $self->{perfdata}->threshold_check(
|
||||||
threshold => [ { label => 'critical-' . $self->{label}, exit_litteral => 'critical' }, { label => 'warning-'. $self->{label}, exit_litteral => 'warning' } ]);
|
value => $self->{result_values}->{volume},
|
||||||
|
threshold => [ { label => 'critical-' . $self->{label}, exit_litteral => 'critical' }, { label => 'warning-'. $self->{label}, exit_litteral => 'warning' } ]
|
||||||
|
);
|
||||||
return $exit;
|
return $exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -62,37 +64,19 @@ sub custom_volume_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my ($volume_value, $volume_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{volume});
|
my ($volume_value, $volume_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{volume});
|
||||||
my $msg = sprintf("%s: %s %s", $self->{result_values}->{display}, $volume_value, $volume_unit);
|
return sprintf('%s: %s %s', $self->{result_values}->{display}, $volume_value, $volume_unit);
|
||||||
return $msg;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_volume_calc {
|
sub custom_volume_calc {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{result_values}->{volume} = $self->{instance_mode}->convert_to_bytes(raw_value => $options{new_datas}->{$self->{instance} . '_' . $options{extra_options}->{label_ref}});
|
$self->{result_values}->{volume} = $options{new_datas}->{$self->{instance} . '_' . $options{extra_options}->{label_ref}};
|
||||||
$self->{result_values}->{display} = $options{extra_options}->{display_ref};
|
$self->{result_values}->{display} = $options{extra_options}->{display_ref};
|
||||||
$self->{result_values}->{label} = $options{extra_options}->{label_ref};
|
$self->{result_values}->{label} = $options{extra_options}->{label_ref};
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
sub convert_to_bytes {
|
|
||||||
my ($class, %options) = @_;
|
|
||||||
|
|
||||||
my ($value, $unit) = split(/\s+/, $options{raw_value});
|
|
||||||
if ($unit =~ /kb*/i) {
|
|
||||||
$value = $value * 1024;
|
|
||||||
} elsif ($unit =~ /mb*/i) {
|
|
||||||
$value = $value * 1024 * 1024;
|
|
||||||
} elsif ($unit =~ /gb*/i) {
|
|
||||||
$value = $value * 1024 * 1024 * 1024;
|
|
||||||
} elsif ($unit =~ /tb*/i) {
|
|
||||||
$value = $value * 1024 * 1024 * 1024 * 1024;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $value;
|
|
||||||
}
|
|
||||||
|
|
||||||
sub set_counters {
|
sub set_counters {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
@ -153,20 +137,10 @@ 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 => {
|
||||||
{
|
'warning-status:s' => { name => 'warning_status', default => '' },
|
||||||
"hostname:s" => { name => 'hostname' },
|
'critical-status:s' => { name => 'critical_status', default => '%{reclamation_status} !~ /ready/i' },
|
||||||
"ssh-option:s@" => { name => 'ssh_option' },
|
});
|
||||||
"ssh-path:s" => { name => 'ssh_path' },
|
|
||||||
"ssh-command:s" => { name => 'ssh_command', default => 'ssh' },
|
|
||||||
"timeout:s" => { name => 'timeout', default => 30 },
|
|
||||||
"sudo" => { name => 'sudo' },
|
|
||||||
"command:s" => { name => 'command', default => 'syscli' },
|
|
||||||
"command-path:s" => { name => 'command_path' },
|
|
||||||
"command-options:s" => { name => 'command_options', default => '--getstatus reclamation' },
|
|
||||||
"warning-status:s" => { name => 'warning_status', default => '' },
|
|
||||||
"critical-status:s" => { name => 'critical_status', default => '%{reclamation_status} !~ /ready/i' },
|
|
||||||
});
|
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
@ -175,25 +149,13 @@ sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::check_options(%options);
|
$self->SUPER::check_options(%options);
|
||||||
|
|
||||||
if (defined($self->{option_results}->{hostname}) && $self->{option_results}->{hostname} ne '') {
|
|
||||||
$self->{option_results}->{remote} = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
$self->change_macros(macros => ['warning_status', 'critical_status']);
|
$self->change_macros(macros => ['warning_status', 'critical_status']);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{global} = {};
|
my $stdout = $options{custom}->execute_command(command => 'syscli --getstatus reclamation');
|
||||||
|
|
||||||
my ($stdout, $exit_code) = centreon::plugins::misc::execute(output => $self->{output},
|
|
||||||
options => $self->{option_results},
|
|
||||||
sudo => $self->{option_results}->{sudo},
|
|
||||||
command => $self->{option_results}->{command},
|
|
||||||
command_path => $self->{option_results}->{command_path},
|
|
||||||
command_options => $self->{option_results}->{command_options},
|
|
||||||
);
|
|
||||||
# Output data:
|
# Output data:
|
||||||
# Reclamation Status =
|
# Reclamation Status =
|
||||||
# Stage Status Progress = 100 %
|
# Stage Status Progress = 100 %
|
||||||
|
@ -204,12 +166,13 @@ sub manage_selection {
|
||||||
# Number of Stages = 2
|
# Number of Stages = 2
|
||||||
# Reclaimable Space = 187.87 GB
|
# Reclaimable Space = 187.87 GB
|
||||||
|
|
||||||
|
$self->{global} = {};
|
||||||
foreach (split(/\n/, $stdout)) {
|
foreach (split(/\n/, $stdout)) {
|
||||||
$self->{global}->{reclamation_status} = $1 if ($_ =~ /.*Reclamation\sStatus\s=\s(.*)$/i);
|
$self->{global}->{reclamation_status} = $1 if (/.*Reclamation\sStatus\s=\s(.*)$/i);
|
||||||
$self->{global}->{stage_status_progress} = $1 if ($_ =~ /.*Stage\sStatus\sProgress\s=\s(.*)\s%$/i);
|
$self->{global}->{stage_status_progress} = $1 if (/.*Stage\sStatus\sProgress\s=\s(.*)\s%$/i);
|
||||||
$self->{global}->{total_progress} = $1 if ($_ =~ /.*Total\sProgress\s=\s(.*)\s%$/i);
|
$self->{global}->{total_progress} = $1 if (/.*Total\sProgress\s=\s(.*)\s%$/i);
|
||||||
$self->{global}->{data_scanned} = $1 if ($_ =~ /.*Data\sScanned\s=\s(.*)$/i);
|
$self->{global}->{data_scanned} = $options{custom}->convert_to_bytes(raw_value => $1) if (/.*Data\sScanned\s=\s(.*)$/i);
|
||||||
$self->{global}->{reclaimable_space} = $1 if ($_ =~ /.*Reclaimable\sSpace\s=\s(.*)$/i);
|
$self->{global}->{reclaimable_space} = $options{custom}->convert_to_bytes(raw_value => $1) if (/.*Reclaimable\sSpace\s=\s(.*)$/i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -223,10 +186,6 @@ Check reclamation status and volumes.
|
||||||
|
|
||||||
=over 8
|
=over 8
|
||||||
|
|
||||||
=item B<--hostname>
|
|
||||||
|
|
||||||
Hostname to query.
|
|
||||||
|
|
||||||
=item B<--filter-counters>
|
=item B<--filter-counters>
|
||||||
|
|
||||||
Only display some counters (regexp can be used).
|
Only display some counters (regexp can be used).
|
||||||
|
@ -242,48 +201,11 @@ Can used special variables like: %{reclamation_status}
|
||||||
Set critical threshold for status (Default: '%{reclamation_status} !~ /ready/i').
|
Set critical threshold for status (Default: '%{reclamation_status} !~ /ready/i').
|
||||||
Can used special variables like: %{reclamation_status}
|
Can used special variables like: %{reclamation_status}
|
||||||
|
|
||||||
=item B<--warning-*>
|
=item B<--warning-*> B<--critical-*>
|
||||||
|
|
||||||
Threshold warning.
|
Thresholds.
|
||||||
Can be: 'status-progress', 'compacted', 'still-to-compact'.
|
Can be: 'status-progress', 'compacted', 'still-to-compact'.
|
||||||
|
|
||||||
=item B<--critical-*>
|
|
||||||
|
|
||||||
Threshold critical.
|
|
||||||
Can be: 'status-progress', 'compacted', 'still-to-compact'.
|
|
||||||
|
|
||||||
=item B<--ssh-option>
|
|
||||||
|
|
||||||
Specify multiple options like the user (example: --ssh-option='-l=centreon-engine' --ssh-option='-p=52').
|
|
||||||
|
|
||||||
=item B<--ssh-path>
|
|
||||||
|
|
||||||
Specify ssh command path (default: none)
|
|
||||||
|
|
||||||
=item B<--ssh-command>
|
|
||||||
|
|
||||||
Specify ssh command (default: 'ssh'). Useful to use 'plink'.
|
|
||||||
|
|
||||||
=item B<--timeout>
|
|
||||||
|
|
||||||
Timeout in seconds for the command (Default: 30).
|
|
||||||
|
|
||||||
=item B<--sudo>
|
|
||||||
|
|
||||||
Use 'sudo' to execute the command.
|
|
||||||
|
|
||||||
=item B<--command>
|
|
||||||
|
|
||||||
Command to get information (Default: 'syscli').
|
|
||||||
|
|
||||||
=item B<--command-path>
|
|
||||||
|
|
||||||
Command path.
|
|
||||||
|
|
||||||
=item B<--command-options>
|
|
||||||
|
|
||||||
Command options (Default: '--getstatus reclamation').
|
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
|
@ -28,18 +28,21 @@ use warnings;
|
||||||
sub custom_volume_perfdata {
|
sub custom_volume_perfdata {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{output}->perfdata_add(label => $self->{result_values}->{label}, unit => 'B',
|
$self->{output}->perfdata_add(
|
||||||
value => $self->{result_values}->{volume},
|
label => $self->{result_values}->{label}, unit => 'B',
|
||||||
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{label}),
|
value => $self->{result_values}->{volume},
|
||||||
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{label})
|
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{label}),
|
||||||
);
|
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{label})
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_volume_threshold {
|
sub custom_volume_threshold {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $exit = $self->{perfdata}->threshold_check(value => $self->{result_values}->{volume},
|
my $exit = $self->{perfdata}->threshold_check(
|
||||||
threshold => [ { label => 'critical-' . $self->{label}, exit_litteral => 'critical' }, { label => 'warning-'. $self->{label}, exit_litteral => 'warning' } ]);
|
value => $self->{result_values}->{volume},
|
||||||
|
threshold => [ { label => 'critical-' . $self->{label}, exit_litteral => 'critical' }, { label => 'warning-'. $self->{label}, exit_litteral => 'warning' } ]
|
||||||
|
);
|
||||||
return $exit;
|
return $exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -47,37 +50,19 @@ sub custom_volume_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my ($volume_value, $volume_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{volume});
|
my ($volume_value, $volume_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{volume});
|
||||||
my $msg = sprintf("%s: %s %s", $self->{result_values}->{display}, $volume_value, $volume_unit);
|
return sprintf('%s: %s %s', $self->{result_values}->{display}, $volume_value, $volume_unit);
|
||||||
return $msg;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_volume_calc {
|
sub custom_volume_calc {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{result_values}->{volume} = $self->{instance_mode}->convert_to_bytes(raw_value => $options{new_datas}->{$self->{instance} . '_' . $options{extra_options}->{label_ref}});
|
$self->{result_values}->{volume} = $options{new_datas}->{$self->{instance} . '_' . $options{extra_options}->{label_ref}};
|
||||||
$self->{result_values}->{display} = $options{extra_options}->{display_ref};
|
$self->{result_values}->{display} = $options{extra_options}->{display_ref};
|
||||||
$self->{result_values}->{label} = $options{extra_options}->{label_ref};
|
$self->{result_values}->{label} = $options{extra_options}->{label_ref};
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
sub convert_to_bytes {
|
|
||||||
my ($class, %options) = @_;
|
|
||||||
|
|
||||||
my ($value, $unit) = split(/\s+/, $options{raw_value});
|
|
||||||
if ($unit =~ /kb*/i) {
|
|
||||||
$value = $value * 1024;
|
|
||||||
} elsif ($unit =~ /mb*/i) {
|
|
||||||
$value = $value * 1024 * 1024;
|
|
||||||
} elsif ($unit =~ /gb*/i) {
|
|
||||||
$value = $value * 1024 * 1024 * 1024;
|
|
||||||
} elsif ($unit =~ /tb*/i) {
|
|
||||||
$value = $value * 1024 * 1024 * 1024 * 1024;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $value;
|
|
||||||
}
|
|
||||||
|
|
||||||
sub set_counters {
|
sub set_counters {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
@ -194,41 +179,15 @@ sub new {
|
||||||
bless $self, $class;
|
bless $self, $class;
|
||||||
|
|
||||||
$options{options}->add_options(arguments => {
|
$options{options}->add_options(arguments => {
|
||||||
"hostname:s" => { name => 'hostname' },
|
|
||||||
"ssh-option:s@" => { name => 'ssh_option' },
|
|
||||||
"ssh-path:s" => { name => 'ssh_path' },
|
|
||||||
"ssh-command:s" => { name => 'ssh_command', default => 'ssh' },
|
|
||||||
"timeout:s" => { name => 'timeout', default => 30 },
|
|
||||||
"sudo" => { name => 'sudo' },
|
|
||||||
"command:s" => { name => 'command', default => 'syscli' },
|
|
||||||
"command-path:s" => { name => 'command_path' },
|
|
||||||
"command-options:s" => { name => 'command_options', default => '--get datareductionstat' },
|
|
||||||
});
|
});
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
sub check_options {
|
|
||||||
my ($self, %options) = @_;
|
|
||||||
$self->SUPER::check_options(%options);
|
|
||||||
|
|
||||||
if (defined($self->{option_results}->{hostname}) && $self->{option_results}->{hostname} ne '') {
|
|
||||||
$self->{option_results}->{remote} = 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{global} = {};
|
my $stdout = $options{custom}->execute_command(command => 'syscli --get datareductionstat');
|
||||||
|
|
||||||
my ($stdout, $exit_code) = centreon::plugins::misc::execute(output => $self->{output},
|
|
||||||
options => $self->{option_results},
|
|
||||||
sudo => $self->{option_results}->{sudo},
|
|
||||||
command => $self->{option_results}->{command},
|
|
||||||
command_path => $self->{option_results}->{command_path},
|
|
||||||
command_options => $self->{option_results}->{command_options},
|
|
||||||
);
|
|
||||||
# Output data:
|
# Output data:
|
||||||
# Data Size Before Reduction = 346.08 TB
|
# Data Size Before Reduction = 346.08 TB
|
||||||
# - Incoming Namespace = 0.00 MB
|
# - Incoming Namespace = 0.00 MB
|
||||||
|
@ -242,18 +201,19 @@ sub manage_selection {
|
||||||
# - Deduplication Ratio = 3.95 : 1
|
# - Deduplication Ratio = 3.95 : 1
|
||||||
# - Compression Ratio = 1.33 : 1
|
# - Compression Ratio = 1.33 : 1
|
||||||
|
|
||||||
|
$self->{global} = {};
|
||||||
foreach (split(/\n/, $stdout)) {
|
foreach (split(/\n/, $stdout)) {
|
||||||
$self->{global}->{size_before_reduction} = $1 if ($_ =~ /.*Data\sSize\sBefore\sReduction\s=\s(.*)$/i);
|
$self->{global}->{size_before_reduction} = $options{custom}->convert_to_bytes(raw_value => $1) if (/.*Data\sSize\sBefore\sReduction\s=\s(.*)$/i);
|
||||||
$self->{global}->{incoming_namespace} = $1 if ($_ =~ /.*Incoming\sNamespace\s=\s(.*)$/i);
|
$self->{global}->{incoming_namespace} = $options{custom}->convert_to_bytes(raw_value => $1) if (/.*Incoming\sNamespace\s=\s(.*)$/i);
|
||||||
$self->{global}->{nfs_deduplicated_shares} = $1 if ($_ =~ /.*NFS\sDeduplicated\sShares\s=\s(.*)$/i);
|
$self->{global}->{nfs_deduplicated_shares} = $options{custom}->convert_to_bytes(raw_value => $1) if (/.*NFS\sDeduplicated\sShares\s=\s(.*)$/i);
|
||||||
$self->{global}->{cifs_smb_deduplicated_shares} = $1 if ($_ =~ /.*CIFS\/SMB\sDeduplicated\sShares\s=\s(.*)$/i);
|
$self->{global}->{cifs_smb_deduplicated_shares} = $options{custom}->convert_to_bytes(raw_value => $1) if (/.*CIFS\/SMB\sDeduplicated\sShares\s=\s(.*)$/i);
|
||||||
$self->{global}->{application_specific_deduplicated_shares} = $1 if ($_ =~ /.*Application\sSpecific\sDeduplicated\sShares\s=\s(.*)$/i);
|
$self->{global}->{application_specific_deduplicated_shares} = $options{custom}->convert_to_bytes(raw_value => $1) if (/.*Application\sSpecific\sDeduplicated\sShares\s=\s(.*)$/i);
|
||||||
$self->{global}->{deduplicated_partitions} = $1 if ($_ =~ /.*Deduplicated\sPartitions\s=\s(.*)$/i);
|
$self->{global}->{deduplicated_partitions} = $options{custom}->convert_to_bytes(raw_value => $1) if (/.*Deduplicated\sPartitions\s=\s(.*)$/i);
|
||||||
$self->{global}->{ost_storage_servers} = $1 if ($_ =~ /.*OST\sStorage\sServers\s=\s(.*)$/i);
|
$self->{global}->{ost_storage_servers} = $options{custom}->convert_to_bytes(raw_value => $1) if (/.*OST\sStorage\sServers\s=\s(.*)$/i);
|
||||||
$self->{global}->{size_after_reduction} = $1 if ($_ =~ /.*Data\sSize\sAfter\sReduction\s=\s(.*)$/i);
|
$self->{global}->{size_after_reduction} = $options{custom}->convert_to_bytes(raw_value => $1) if (/.*Data\sSize\sAfter\sReduction\s=\s(.*)$/i);
|
||||||
$self->{global}->{total_reduction_ratio} = $1 if ($_ =~ /.*Total\sReduction\sRatio\s=\s(.*)\s:\s1$/i);
|
$self->{global}->{total_reduction_ratio} = $1 if (/.*Total\sReduction\sRatio\s=\s(.*)\s:\s1$/i);
|
||||||
$self->{global}->{deduplication_ratio} = $1 if ($_ =~ /.*Deduplication\sRatio\s=\s(.*)\s:\s1$/i);
|
$self->{global}->{deduplication_ratio} = $1 if (/.*Deduplication\sRatio\s=\s(.*)\s:\s1$/i);
|
||||||
$self->{global}->{compression_ratio} = $1 if ($_ =~ /.*Compression\sRatio\s=\s(.*)\s:\s1$/i);
|
$self->{global}->{compression_ratio} = $1 if (/.*Compression\sRatio\s=\s(.*)\s:\s1$/i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -267,65 +227,20 @@ Check data reduction statistics.
|
||||||
|
|
||||||
=over 8
|
=over 8
|
||||||
|
|
||||||
=item B<--hostname>
|
|
||||||
|
|
||||||
Hostname to query.
|
|
||||||
|
|
||||||
=item B<--filter-counters>
|
=item B<--filter-counters>
|
||||||
|
|
||||||
Only display some counters (regexp can be used).
|
Only display some counters (regexp can be used).
|
||||||
Example: --filter-counters='ratio'
|
Example: --filter-counters='ratio'
|
||||||
|
|
||||||
=item B<--warning-*>
|
=item B<--warning-*> B<--critical-*>
|
||||||
|
|
||||||
Threshold warning.
|
Thresholds.
|
||||||
Can be: 'size-before-reduction', 'size-after-reduction', 'incoming-namespace',
|
Can be: 'size-before-reduction', 'size-after-reduction', 'incoming-namespace',
|
||||||
'nfs-deduplicated-shares', cifs-smb-deduplicated-shares',
|
'nfs-deduplicated-shares', cifs-smb-deduplicated-shares',
|
||||||
'application-specific-deduplicated-shares', 'deduplicated-partitions',
|
'application-specific-deduplicated-shares', 'deduplicated-partitions',
|
||||||
'ost-storage-servers', 'total-reduction-ratio',
|
'ost-storage-servers', 'total-reduction-ratio',
|
||||||
'deduplication-ratio', 'compression-ratio'.
|
'deduplication-ratio', 'compression-ratio'.
|
||||||
|
|
||||||
=item B<--critical-*>
|
|
||||||
|
|
||||||
Threshold critical.
|
|
||||||
Can be: 'size-before-reduction', 'size-after-reduction', 'incoming-namespace',
|
|
||||||
'nfs-deduplicated-shares', cifs-smb-deduplicated-shares',
|
|
||||||
'application-specific-deduplicated-shares', 'deduplicated-partitions',
|
|
||||||
'ost-storage-servers', 'total-reduction-ratio',
|
|
||||||
'deduplication-ratio', 'compression-ratio'.
|
|
||||||
|
|
||||||
=item B<--ssh-option>
|
|
||||||
|
|
||||||
Specify multiple options like the user (example: --ssh-option='-l=centreon-engine' --ssh-option='-p=52').
|
|
||||||
|
|
||||||
=item B<--ssh-path>
|
|
||||||
|
|
||||||
Specify ssh command path (default: none)
|
|
||||||
|
|
||||||
=item B<--ssh-command>
|
|
||||||
|
|
||||||
Specify ssh command (default: 'ssh'). Useful to use 'plink'.
|
|
||||||
|
|
||||||
=item B<--timeout>
|
|
||||||
|
|
||||||
Timeout in seconds for the command (Default: 30).
|
|
||||||
|
|
||||||
=item B<--sudo>
|
|
||||||
|
|
||||||
Use 'sudo' to execute the command.
|
|
||||||
|
|
||||||
=item B<--command>
|
|
||||||
|
|
||||||
Command to get information (Default: 'syscli').
|
|
||||||
|
|
||||||
=item B<--command-path>
|
|
||||||
|
|
||||||
Command path.
|
|
||||||
|
|
||||||
=item B<--command-options>
|
|
||||||
|
|
||||||
Command options (Default: '--get datareductionstat').
|
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
|
@ -29,8 +29,7 @@ use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold)
|
||||||
sub custom_status_output {
|
sub custom_status_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $msg = "status is '" . $self->{result_values}->{status} . "'";
|
return "status is '" . $self->{result_values}->{status} . "'";
|
||||||
return $msg;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_status_calc {
|
sub custom_status_calc {
|
||||||
|
@ -71,20 +70,10 @@ 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 => {
|
||||||
{
|
'warning-status:s' => { name => 'warning_status' },
|
||||||
"hostname:s" => { name => 'hostname' },
|
'critical-status:s' => { name => 'critical_status', default => '%{status} !~ /Normal/i' },
|
||||||
"ssh-option:s@" => { name => 'ssh_option' },
|
});
|
||||||
"ssh-path:s" => { name => 'ssh_path' },
|
|
||||||
"ssh-command:s" => { name => 'ssh_command', default => 'ssh' },
|
|
||||||
"timeout:s" => { name => 'timeout', default => 30 },
|
|
||||||
"sudo" => { name => 'sudo' },
|
|
||||||
"command:s" => { name => 'command', default => 'syscli' },
|
|
||||||
"command-path:s" => { name => 'command_path' },
|
|
||||||
"command-options:s" => { name => 'command_options', default => '--getstatus storagearray' },
|
|
||||||
"warning-status:s" => { name => 'warning_status' },
|
|
||||||
"critical-status:s" => { name => 'critical_status', default => '%{status} !~ /Normal/i' },
|
|
||||||
});
|
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
@ -93,25 +82,13 @@ sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::check_options(%options);
|
$self->SUPER::check_options(%options);
|
||||||
|
|
||||||
if (defined($self->{option_results}->{hostname}) && $self->{option_results}->{hostname} ne '') {
|
|
||||||
$self->{option_results}->{remote} = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
$self->change_macros(macros => ['warning_status', 'critical_status']);
|
$self->change_macros(macros => ['warning_status', 'critical_status']);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{global} = {};
|
my $stdout = $options{custom}->execute_command(command => 'syscli --getstatus storagearray');
|
||||||
|
|
||||||
my ($stdout, $exit_code) = centreon::plugins::misc::execute(output => $self->{output},
|
|
||||||
options => $self->{option_results},
|
|
||||||
sudo => $self->{option_results}->{sudo},
|
|
||||||
command => $self->{option_results}->{command},
|
|
||||||
command_path => $self->{option_results}->{command_path},
|
|
||||||
command_options => $self->{option_results}->{command_options},
|
|
||||||
);
|
|
||||||
# Output data:
|
# Output data:
|
||||||
# List of Storage Arrays:
|
# List of Storage Arrays:
|
||||||
# Total Count = 2
|
# Total Count = 2
|
||||||
|
@ -122,11 +99,12 @@ sub manage_selection {
|
||||||
# Name = a0
|
# Name = a0
|
||||||
# Status = Normal
|
# Status = Normal
|
||||||
|
|
||||||
|
$self->{global} = {};
|
||||||
my $id;
|
my $id;
|
||||||
foreach (split(/\n/, $stdout)) {
|
foreach (split(/\n/, $stdout)) {
|
||||||
$id = $1 if ($_ =~ /.*\[Array\s=\s(.*)\]$/i);
|
$id = $1 if (/.*\[Array\s=\s(.*)\]$/i);
|
||||||
$self->{global}->{$id}->{status} = $1 if ($_ =~ /.*Status\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{status} = $1 if (/.*Status\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
$self->{global}->{$id}->{name} = $1 if ($_ =~ /.*Name\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{name} = $1 if (/.*Name\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -140,10 +118,6 @@ Check storage array status.
|
||||||
|
|
||||||
=over 8
|
=over 8
|
||||||
|
|
||||||
=item B<--hostname>
|
|
||||||
|
|
||||||
Hostname to query.
|
|
||||||
|
|
||||||
=item B<--warning-status>
|
=item B<--warning-status>
|
||||||
|
|
||||||
Set warning threshold for status (Default: '').
|
Set warning threshold for status (Default: '').
|
||||||
|
@ -154,38 +128,6 @@ Can used special variables like: %{name}, %{status}
|
||||||
Set critical threshold for status (Default: '%{status} !~ /Normal/i').
|
Set critical threshold for status (Default: '%{status} !~ /Normal/i').
|
||||||
Can used special variables like: %{name}, %{status}
|
Can used special variables like: %{name}, %{status}
|
||||||
|
|
||||||
=item B<--ssh-option>
|
|
||||||
|
|
||||||
Specify multiple options like the user (example: --ssh-option='-l=centreon-engine' --ssh-option='-p=52').
|
|
||||||
|
|
||||||
=item B<--ssh-path>
|
|
||||||
|
|
||||||
Specify ssh command path (default: none)
|
|
||||||
|
|
||||||
=item B<--ssh-command>
|
|
||||||
|
|
||||||
Specify ssh command (default: 'ssh'). Useful to use 'plink'.
|
|
||||||
|
|
||||||
=item B<--timeout>
|
|
||||||
|
|
||||||
Timeout in seconds for the command (Default: 30).
|
|
||||||
|
|
||||||
=item B<--sudo>
|
|
||||||
|
|
||||||
Use 'sudo' to execute the command.
|
|
||||||
|
|
||||||
=item B<--command>
|
|
||||||
|
|
||||||
Command to get information (Default: 'syscli').
|
|
||||||
|
|
||||||
=item B<--command-path>
|
|
||||||
|
|
||||||
Command path.
|
|
||||||
|
|
||||||
=item B<--command-options>
|
|
||||||
|
|
||||||
Command options (Default: '--getstatus storagearray').
|
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
|
@ -29,8 +29,7 @@ use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold)
|
||||||
sub custom_status_output {
|
sub custom_status_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $msg = "status is '" . $self->{result_values}->{status} . "' [type = " . $self->{result_values}->{type} . "] [value = " . $self->{result_values}->{value} . "]";
|
return "status is '" . $self->{result_values}->{status} . "' [type = " . $self->{result_values}->{type} . "] [value = " . $self->{result_values}->{value} . "]";
|
||||||
return $msg;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_status_calc {
|
sub custom_status_calc {
|
||||||
|
@ -73,20 +72,10 @@ 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 => {
|
||||||
{
|
'warning-status:s' => { name => 'warning_status' },
|
||||||
"hostname:s" => { name => 'hostname' },
|
'critical-status:s' => { name => 'critical_status', default => '%{status} !~ /Normal/i' }
|
||||||
"ssh-option:s@" => { name => 'ssh_option' },
|
});
|
||||||
"ssh-path:s" => { name => 'ssh_path' },
|
|
||||||
"ssh-command:s" => { name => 'ssh_command', default => 'ssh' },
|
|
||||||
"timeout:s" => { name => 'timeout', default => 30 },
|
|
||||||
"sudo" => { name => 'sudo' },
|
|
||||||
"command:s" => { name => 'command', default => 'syscli' },
|
|
||||||
"command-path:s" => { name => 'command_path' },
|
|
||||||
"command-options:s" => { name => 'command_options', default => '--getstatus systemboard' },
|
|
||||||
"warning-status:s" => { name => 'warning_status' },
|
|
||||||
"critical-status:s" => { name => 'critical_status', default => '%{status} !~ /Normal/i' },
|
|
||||||
});
|
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
@ -95,25 +84,13 @@ sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::check_options(%options);
|
$self->SUPER::check_options(%options);
|
||||||
|
|
||||||
if (defined($self->{option_results}->{hostname}) && $self->{option_results}->{hostname} ne '') {
|
|
||||||
$self->{option_results}->{remote} = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
$self->change_macros(macros => ['warning_status', 'critical_status']);
|
$self->change_macros(macros => ['warning_status', 'critical_status']);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{global} = {};
|
my $stdout = $options{custom}->execute_command(command => 'syscli --getstatus systemboard');
|
||||||
|
|
||||||
my ($stdout, $exit_code) = centreon::plugins::misc::execute(output => $self->{output},
|
|
||||||
options => $self->{option_results},
|
|
||||||
sudo => $self->{option_results}->{sudo},
|
|
||||||
command => $self->{option_results}->{command},
|
|
||||||
command_path => $self->{option_results}->{command_path},
|
|
||||||
command_options => $self->{option_results}->{command_options},
|
|
||||||
);
|
|
||||||
# Output data:
|
# Output data:
|
||||||
# System Board Components
|
# System Board Components
|
||||||
# Total count = 45
|
# Total count = 45
|
||||||
|
@ -133,13 +110,14 @@ sub manage_selection {
|
||||||
# Value = 31 degrees C
|
# Value = 31 degrees C
|
||||||
# Status = Normal
|
# Status = Normal
|
||||||
|
|
||||||
|
$self->{global} = {};
|
||||||
my $id;
|
my $id;
|
||||||
foreach (split(/\n/, $stdout)) {
|
foreach (split(/\n/, $stdout)) {
|
||||||
$id = $1 if ($_ =~ /.*\[Component\s=\s(.*)\]$/i);
|
$id = $1 if (/.*\[Component\s=\s(.*)\]$/i);
|
||||||
$self->{global}->{$id}->{status} = $1 if ($_ =~ /.*Status\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{status} = $1 if (/.*Status\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
$self->{global}->{$id}->{name} = $1 if ($_ =~ /.*Name\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{name} = $1 if (/.*Name\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
$self->{global}->{$id}->{type} = $1 if ($_ =~ /.*Type\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{type} = $1 if (/.*Type\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
$self->{global}->{$id}->{value} = $1 if ($_ =~ /.*Value\s=\s(.*)$/i && defined($id) && $id ne '');
|
$self->{global}->{$id}->{value} = $1 if (/.*Value\s=\s(.*)$/i && defined($id) && $id ne '');
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -153,10 +131,6 @@ Check system board status.
|
||||||
|
|
||||||
=over 8
|
=over 8
|
||||||
|
|
||||||
=item B<--hostname>
|
|
||||||
|
|
||||||
Hostname to query.
|
|
||||||
|
|
||||||
=item B<--warning-status>
|
=item B<--warning-status>
|
||||||
|
|
||||||
Set warning threshold for status (Default: '').
|
Set warning threshold for status (Default: '').
|
||||||
|
@ -167,38 +141,6 @@ Can used special variables like: %{name}, %{status}
|
||||||
Set critical threshold for status (Default: '%{status} !~ /Normal/i').
|
Set critical threshold for status (Default: '%{status} !~ /Normal/i').
|
||||||
Can used special variables like: %{name}, %{status}
|
Can used special variables like: %{name}, %{status}
|
||||||
|
|
||||||
=item B<--ssh-option>
|
|
||||||
|
|
||||||
Specify multiple options like the user (example: --ssh-option='-l=centreon-engine' --ssh-option='-p=52').
|
|
||||||
|
|
||||||
=item B<--ssh-path>
|
|
||||||
|
|
||||||
Specify ssh command path (default: none)
|
|
||||||
|
|
||||||
=item B<--ssh-command>
|
|
||||||
|
|
||||||
Specify ssh command (default: 'ssh'). Useful to use 'plink'.
|
|
||||||
|
|
||||||
=item B<--timeout>
|
|
||||||
|
|
||||||
Timeout in seconds for the command (Default: 30).
|
|
||||||
|
|
||||||
=item B<--sudo>
|
|
||||||
|
|
||||||
Use 'sudo' to execute the command.
|
|
||||||
|
|
||||||
=item B<--command>
|
|
||||||
|
|
||||||
Command to get information (Default: 'syscli').
|
|
||||||
|
|
||||||
=item B<--command-path>
|
|
||||||
|
|
||||||
Command path.
|
|
||||||
|
|
||||||
=item B<--command-options>
|
|
||||||
|
|
||||||
Command options (Default: '--getstatus systemboard').
|
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
|
@ -28,18 +28,21 @@ use warnings;
|
||||||
sub custom_volume_perfdata {
|
sub custom_volume_perfdata {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{output}->perfdata_add(label => $self->{result_values}->{label}, unit => 'B/s',
|
$self->{output}->perfdata_add(
|
||||||
value => $self->{result_values}->{volume},
|
label => $self->{result_values}->{label}, unit => 'B/s',
|
||||||
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{label}),
|
value => $self->{result_values}->{volume},
|
||||||
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{label})
|
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warning-' . $self->{label}),
|
||||||
);
|
critical => $self->{perfdata}->get_perfdata_for_output(label => 'critical-' . $self->{label})
|
||||||
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_volume_threshold {
|
sub custom_volume_threshold {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $exit = $self->{perfdata}->threshold_check(value => $self->{result_values}->{volume},
|
my $exit = $self->{perfdata}->threshold_check(
|
||||||
threshold => [ { label => 'critical-' . $self->{label}, exit_litteral => 'critical' }, { label => 'warning-'. $self->{label}, exit_litteral => 'warning' } ]);
|
value => $self->{result_values}->{volume},
|
||||||
|
threshold => [ { label => 'critical-' . $self->{label}, exit_litteral => 'critical' }, { label => 'warning-'. $self->{label}, exit_litteral => 'warning' } ]
|
||||||
|
);
|
||||||
return $exit;
|
return $exit;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -47,37 +50,19 @@ sub custom_volume_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my ($volume_value, $volume_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{volume});
|
my ($volume_value, $volume_unit) = $self->{perfdata}->change_bytes(value => $self->{result_values}->{volume});
|
||||||
my $msg = sprintf("%s: %s %s/s", $self->{result_values}->{display}, $volume_value, $volume_unit);
|
return sprintf("%s: %s %s/s", $self->{result_values}->{display}, $volume_value, $volume_unit);
|
||||||
return $msg;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub custom_volume_calc {
|
sub custom_volume_calc {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{result_values}->{volume} = $self->{instance_mode}->convert_to_bytes(raw_value => $options{new_datas}->{$self->{instance} . '_' . $options{extra_options}->{label_ref}});
|
$self->{result_values}->{volume} = $options{new_datas}->{$self->{instance} . '_' . $options{extra_options}->{label_ref}};
|
||||||
$self->{result_values}->{display} = $options{extra_options}->{display_ref};
|
$self->{result_values}->{display} = $options{extra_options}->{display_ref};
|
||||||
$self->{result_values}->{label} = $options{extra_options}->{label_ref};
|
$self->{result_values}->{label} = $options{extra_options}->{label_ref};
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
sub convert_to_bytes {
|
|
||||||
my ($class, %options) = @_;
|
|
||||||
|
|
||||||
my ($value, $unit) = split(/\s+/, $options{raw_value});
|
|
||||||
if ($unit =~ /kb*/i) {
|
|
||||||
$value = $value * 1024;
|
|
||||||
} elsif ($unit =~ /mb*/i) {
|
|
||||||
$value = $value * 1024 * 1024;
|
|
||||||
} elsif ($unit =~ /gb*/i) {
|
|
||||||
$value = $value * 1024 * 1024 * 1024;
|
|
||||||
} elsif ($unit =~ /tb*/i) {
|
|
||||||
$value = $value * 1024 * 1024 * 1024 * 1024;
|
|
||||||
}
|
|
||||||
|
|
||||||
return $value;
|
|
||||||
}
|
|
||||||
|
|
||||||
sub set_counters {
|
sub set_counters {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
@ -113,48 +98,22 @@ sub new {
|
||||||
bless $self, $class;
|
bless $self, $class;
|
||||||
|
|
||||||
$options{options}->add_options(arguments => {
|
$options{options}->add_options(arguments => {
|
||||||
"hostname:s" => { name => 'hostname' },
|
|
||||||
"ssh-option:s@" => { name => 'ssh_option' },
|
|
||||||
"ssh-path:s" => { name => 'ssh_path' },
|
|
||||||
"ssh-command:s" => { name => 'ssh_command', default => 'ssh' },
|
|
||||||
"timeout:s" => { name => 'timeout', default => 30 },
|
|
||||||
"sudo" => { name => 'sudo' },
|
|
||||||
"command:s" => { name => 'command', default => 'syscli' },
|
|
||||||
"command-path:s" => { name => 'command_path' },
|
|
||||||
"command-options:s" => { name => 'command_options', default => '--get ingestrate' },
|
|
||||||
});
|
});
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
sub check_options {
|
|
||||||
my ($self, %options) = @_;
|
|
||||||
$self->SUPER::check_options(%options);
|
|
||||||
|
|
||||||
if (defined($self->{option_results}->{hostname}) && $self->{option_results}->{hostname} ne '') {
|
|
||||||
$self->{option_results}->{remote} = 1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{global} = {};
|
my $stdout = $options{custom}->execute_command(command => 'syscli --get ingestrate');
|
||||||
|
|
||||||
my ($stdout, $exit_code) = centreon::plugins::misc::execute(output => $self->{output},
|
|
||||||
options => $self->{option_results},
|
|
||||||
sudo => $self->{option_results}->{sudo},
|
|
||||||
command => $self->{option_results}->{command},
|
|
||||||
command_path => $self->{option_results}->{command_path},
|
|
||||||
command_options => $self->{option_results}->{command_options},
|
|
||||||
);
|
|
||||||
# Output data:
|
# Output data:
|
||||||
# Write Throughput = 0.03 MB/s
|
# Write Throughput = 0.03 MB/s
|
||||||
# Read Throughput = 6.98 MB/s
|
# Read Throughput = 6.98 MB/s
|
||||||
|
$self->{global} = {};
|
||||||
foreach (split(/\n/, $stdout)) {
|
foreach (split(/\n/, $stdout)) {
|
||||||
$self->{global}->{write_rate} = $1 if ($_ =~ /.*Write\sThroughput\s=\s(.*)$/i);
|
$self->{global}->{write_rate} = $options{custom}->convert_to_bytes(raw_value => $1) if (/.*Write\sThroughput\s=\s(.*)$/i)
|
||||||
$self->{global}->{read_rate} = $1 if ($_ =~ /.*Read\sThroughput\s=\s(.*)$/i);
|
$self->{global}->{read_rate} = $options{custom}->convert_to_bytes(raw_value => $1) if (/.*Read\sThroughput\s=\s(.*)$/i);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -168,52 +127,11 @@ Check ingest throughput rate.
|
||||||
|
|
||||||
=over 8
|
=over 8
|
||||||
|
|
||||||
=item B<--hostname>
|
=item B<--warning-*> B<--critical-*>
|
||||||
|
|
||||||
Hostname to query.
|
Thresholds.
|
||||||
|
|
||||||
=item B<--warning-*>
|
|
||||||
|
|
||||||
Threshold warning.
|
|
||||||
Can be: 'read-rate', 'write-rate'.
|
Can be: 'read-rate', 'write-rate'.
|
||||||
|
|
||||||
=item B<--critical-*>
|
|
||||||
|
|
||||||
Threshold critical.
|
|
||||||
Can be: 'read-rate', 'write-rate'.
|
|
||||||
|
|
||||||
=item B<--ssh-option>
|
|
||||||
|
|
||||||
Specify multiple options like the user (example: --ssh-option='-l=centreon-engine' --ssh-option='-p=52').
|
|
||||||
|
|
||||||
=item B<--ssh-path>
|
|
||||||
|
|
||||||
Specify ssh command path (default: none)
|
|
||||||
|
|
||||||
=item B<--ssh-command>
|
|
||||||
|
|
||||||
Specify ssh command (default: 'ssh'). Useful to use 'plink'.
|
|
||||||
|
|
||||||
=item B<--timeout>
|
|
||||||
|
|
||||||
Timeout in seconds for the command (Default: 30).
|
|
||||||
|
|
||||||
=item B<--sudo>
|
|
||||||
|
|
||||||
Use 'sudo' to execute the command.
|
|
||||||
|
|
||||||
=item B<--command>
|
|
||||||
|
|
||||||
Command to get information (Default: 'syscli').
|
|
||||||
|
|
||||||
=item B<--command-path>
|
|
||||||
|
|
||||||
Command path.
|
|
||||||
|
|
||||||
=item B<--command-options>
|
|
||||||
|
|
||||||
Command options (Default: '--get ingestrate').
|
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
|
@ -22,7 +22,7 @@ package storage::quantum::dxi::ssh::plugin;
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use base qw(centreon::plugins::script_simple);
|
use base qw(centreon::plugins::script_custom);
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
|
@ -45,6 +45,7 @@ sub new {
|
||||||
'system-status' => 'storage::quantum::dxi::ssh::mode::systemstatus',
|
'system-status' => 'storage::quantum::dxi::ssh::mode::systemstatus',
|
||||||
'throughput' => 'storage::quantum::dxi::ssh::mode::throughput',
|
'throughput' => 'storage::quantum::dxi::ssh::mode::throughput',
|
||||||
);
|
);
|
||||||
|
$self->{custom_modes}{api} = 'storage::quantum::dxi::ssh::custom::api';
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue