(plugin) network::f5::bigip::snmp - mode pool-status add members information (#3954)
* wip * (plugin) network::f5::bigip::snmp - mode pool-status add members information
This commit is contained in:
parent
b78b99cc36
commit
2122a54e74
|
@ -29,60 +29,18 @@ 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(
|
return sprintf(
|
||||||
'status: %s [state: %s] [reason: %s]',
|
'status: %s [state: %s] [reason: %s]',
|
||||||
$self->{result_values}->{status},
|
$self->{result_values}->{status},
|
||||||
$self->{result_values}->{state},
|
$self->{result_values}->{state},
|
||||||
$self->{result_values}->{reason}
|
$self->{result_values}->{reason}
|
||||||
);
|
);
|
||||||
return $msg;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub set_counters {
|
sub pool_long_output {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
$self->{maps_counters_type} = [
|
return "checking pool '" . $options{instance_value}->{display} . "'";
|
||||||
{ name => 'pool', type => 1, cb_prefix_output => 'prefix_pool_output', message_multiple => 'All Pools are ok', skipped_code => { -10 => 1 } }
|
|
||||||
];
|
|
||||||
|
|
||||||
$self->{maps_counters}->{pool} = [
|
|
||||||
{
|
|
||||||
label => 'status', type => 2, warning_default => '%{state} eq "enabled" and %{status} eq "yellow"', critical_default => '%{state} eq "enabled" and %{status} eq "red"',
|
|
||||||
set => {
|
|
||||||
key_values => [ { name => 'state' }, { name => 'status' }, { name => 'reason' },{ name => 'display' } ],
|
|
||||||
closure_custom_output => $self->can('custom_status_output'),
|
|
||||||
closure_custom_perfdata => sub { return 0; },
|
|
||||||
closure_custom_threshold_check => \&catalog_status_threshold_ng
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{ label => 'current-server-connections', set => {
|
|
||||||
key_values => [ { name => 'ltmPoolStatServerCurConns' }, { name => 'display' } ],
|
|
||||||
output_template => 'current server connections: %s',
|
|
||||||
perfdatas => [
|
|
||||||
{ label => 'current_server_connections', template => '%s',
|
|
||||||
min => 0, label_extra_instance => 1, instance_use => 'display' }
|
|
||||||
]
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{ label => 'current-active-members', display_ok => 0, set => {
|
|
||||||
key_values => [ { name => 'ltmPoolActiveMemberCnt' }, { name => 'display' } ],
|
|
||||||
output_template => 'current active members: %s',
|
|
||||||
perfdatas => [
|
|
||||||
{ label => 'current_active_members', template => '%s',
|
|
||||||
min => 0, label_extra_instance => 1, instance_use => 'display' }
|
|
||||||
]
|
|
||||||
}
|
|
||||||
},
|
|
||||||
{ label => 'current-total-members', display_ok => 0, set => {
|
|
||||||
key_values => [ { name => 'ltmPoolMemberCnt' }, { name => 'display' } ],
|
|
||||||
output_template => 'current total members: %s',
|
|
||||||
perfdatas => [
|
|
||||||
{ label => 'current_total_members', template => '%s',
|
|
||||||
min => 0, label_extra_instance => 1, instance_use => 'display' }
|
|
||||||
]
|
|
||||||
}
|
|
||||||
}
|
|
||||||
];
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub prefix_pool_output {
|
sub prefix_pool_output {
|
||||||
|
@ -91,9 +49,94 @@ sub prefix_pool_output {
|
||||||
return "Pool '" . $options{instance_value}->{display} . "' ";
|
return "Pool '" . $options{instance_value}->{display} . "' ";
|
||||||
}
|
}
|
||||||
|
|
||||||
|
sub prefix_member_output {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
return sprintf(
|
||||||
|
"member node '%s' [port: %s] ",
|
||||||
|
$options{instance_value}->{nodeName},
|
||||||
|
$options{instance_value}->{port}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
sub set_counters {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
$self->{maps_counters_type} = [
|
||||||
|
{ name => 'pools', type => 3, cb_prefix_output => 'prefix_pool_output', cb_long_output => 'pool_long_output', indent_long_output => ' ', message_multiple => 'All pools are ok',
|
||||||
|
group => [
|
||||||
|
{ name => 'pool_status', type => 0, skipped_code => { -10 => 1 } },
|
||||||
|
{ name => 'pool_connections', type => 0, skipped_code => { -10 => 1 } },
|
||||||
|
{ name => 'members', display_long => 1, cb_prefix_output => 'prefix_member_output', message_multiple => 'members are ok', type => 1, skipped_code => { -10 => 1 } },
|
||||||
|
]
|
||||||
|
}
|
||||||
|
];
|
||||||
|
|
||||||
|
$self->{maps_counters}->{pool_status} = [
|
||||||
|
{
|
||||||
|
label => 'status',
|
||||||
|
type => 2,
|
||||||
|
warning_default => '%{membersAllDisabled} eq "no" and %{state} eq "enabled" and %{status} eq "yellow"',
|
||||||
|
critical_default => '%{membersAllDisabled} eq "no" and %{state} eq "enabled" and %{status} eq "red"',
|
||||||
|
set => {
|
||||||
|
key_values => [
|
||||||
|
{ name => 'state' }, { name => 'status' }, { name => 'membersAllDisabled' },
|
||||||
|
{ name => 'reason' }, { name => 'display' }
|
||||||
|
],
|
||||||
|
closure_custom_output => $self->can('custom_status_output'),
|
||||||
|
closure_custom_perfdata => sub { return 0; },
|
||||||
|
closure_custom_threshold_check => \&catalog_status_threshold_ng
|
||||||
|
}
|
||||||
|
}
|
||||||
|
];
|
||||||
|
|
||||||
|
$self->{maps_counters}->{pool_connections} = [
|
||||||
|
{ label => 'current-server-connections', nlabel => 'pool.connections.server.count', set => {
|
||||||
|
key_values => [ { name => 'ltmPoolStatServerCurConns' }, { name => 'display' } ],
|
||||||
|
output_template => 'current server connections: %s',
|
||||||
|
perfdatas => [
|
||||||
|
{ template => '%s', min => 0, label_extra_instance => 1, instance_use => 'display' }
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{ label => 'current-active-members', nlabel => 'pool.members.active.count', set => {
|
||||||
|
key_values => [ { name => 'ltmPoolActiveMemberCnt' }, { name => 'display' } ],
|
||||||
|
output_template => 'current active members: %s',
|
||||||
|
perfdatas => [
|
||||||
|
{ template => '%s', min => 0, label_extra_instance => 1, instance_use => 'display' }
|
||||||
|
]
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{ label => 'current-total-members', display_ok => 0, nlabel => 'pool.members.total.count', set => {
|
||||||
|
key_values => [ { name => 'ltmPoolMemberCnt' }, { name => 'display' } ],
|
||||||
|
output_template => 'current total members: %s',
|
||||||
|
perfdatas => [
|
||||||
|
{ template => '%s', min => 0, label_extra_instance => 1, instance_use => 'display' }
|
||||||
|
]
|
||||||
|
}
|
||||||
|
}
|
||||||
|
];
|
||||||
|
|
||||||
|
$self->{maps_counters}->{members} = [
|
||||||
|
{
|
||||||
|
label => 'member-status',
|
||||||
|
type => 2,
|
||||||
|
set => {
|
||||||
|
key_values => [
|
||||||
|
{ name => 'state' }, { name => 'status' }, { name => 'reason' },
|
||||||
|
{ name => 'poolName' }, { name => 'nodeName' }
|
||||||
|
],
|
||||||
|
closure_custom_output => $self->can('custom_status_output'),
|
||||||
|
closure_custom_perfdata => sub { return 0; },
|
||||||
|
closure_custom_threshold_check => \&catalog_status_threshold_ng
|
||||||
|
}
|
||||||
|
}
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
sub new {
|
sub new {
|
||||||
my ($class, %options) = @_;
|
my ($class, %options) = @_;
|
||||||
my $self = $class->SUPER::new(package => __PACKAGE__, %options);
|
my $self = $class->SUPER::new(package => __PACKAGE__, %options, force_new_perfdata => 1);
|
||||||
bless $self, $class;
|
bless $self, $class;
|
||||||
|
|
||||||
$options{options}->add_options(arguments => {
|
$options{options}->add_options(arguments => {
|
||||||
|
@ -115,15 +158,25 @@ my $map_pool_enabled = {
|
||||||
# New OIDS
|
# New OIDS
|
||||||
my $mapping = {
|
my $mapping = {
|
||||||
new => {
|
new => {
|
||||||
AvailState => { oid => '.1.3.6.1.4.1.3375.2.2.5.5.2.1.2', map => $map_pool_status },
|
status => { oid => '.1.3.6.1.4.1.3375.2.2.5.5.2.1.2', map => $map_pool_status }, # AvailState
|
||||||
EnabledState => { oid => '.1.3.6.1.4.1.3375.2.2.5.5.2.1.3', map => $map_pool_enabled },
|
state => { oid => '.1.3.6.1.4.1.3375.2.2.5.5.2.1.3', map => $map_pool_enabled }, # EnabledState
|
||||||
StatusReason => { oid => '.1.3.6.1.4.1.3375.2.2.5.5.2.1.5' }
|
reason => { oid => '.1.3.6.1.4.1.3375.2.2.5.5.2.1.5' } # StatusReason
|
||||||
},
|
},
|
||||||
old => {
|
old => {
|
||||||
AvailState => { oid => '.1.3.6.1.4.1.3375.2.2.5.1.2.1.18', map => $map_pool_status },
|
status => { oid => '.1.3.6.1.4.1.3375.2.2.5.1.2.1.18', map => $map_pool_status }, # AvailState
|
||||||
EnabledState => { oid => '.1.3.6.1.4.1.3375.2.2.5.1.2.1.19', map => $map_pool_enabled },
|
state => { oid => '.1.3.6.1.4.1.3375.2.2.5.1.2.1.19', map => $map_pool_enabled }, # EnabledState
|
||||||
StatusReason => { oid => '.1.3.6.1.4.1.3375.2.2.5.1.2.1.21' }
|
reason => { oid => '.1.3.6.1.4.1.3375.2.2.5.1.2.1.21' } # StatusReason
|
||||||
|
}
|
||||||
|
};
|
||||||
|
my $mapping_members = {
|
||||||
|
new => {
|
||||||
|
state => { oid => '.1.3.6.1.4.1.3375.2.2.5.6.2.1.6', map => $map_pool_enabled }, # ltmPoolMbrStatusEnabledState
|
||||||
|
reason => { oid => '.1.3.6.1.4.1.3375.2.2.5.6.2.1.8' } # ltmPoolMbrStatusDetailReason
|
||||||
},
|
},
|
||||||
|
old => {
|
||||||
|
state => { oid => '.1.3.6.1.4.1.3375.2.2.5.3.2.1.16', map => $map_pool_enabled }, # ltmPoolMemberEnabledState
|
||||||
|
reason => { oid => '.1.3.6.1.4.1.3375.2.2.5.3.2.1.18' } # ltmPoolMemberStatusReason
|
||||||
|
}
|
||||||
};
|
};
|
||||||
my $mapping2 = {
|
my $mapping2 = {
|
||||||
ltmPoolStatServerCurConns => { oid => '.1.3.6.1.4.1.3375.2.2.5.2.3.1.8' },
|
ltmPoolStatServerCurConns => { oid => '.1.3.6.1.4.1.3375.2.2.5.2.3.1.8' },
|
||||||
|
@ -131,28 +184,79 @@ my $mapping2 = {
|
||||||
ltmPoolMemberCnt => { oid => '.1.3.6.1.4.1.3375.2.2.5.1.2.1.23' }
|
ltmPoolMemberCnt => { oid => '.1.3.6.1.4.1.3375.2.2.5.1.2.1.23' }
|
||||||
};
|
};
|
||||||
|
|
||||||
|
sub add_members {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
my $oid_status = $options{map} eq 'new' ? '.1.3.6.1.4.1.3375.2.2.5.6.2.1.5' : '.1.3.6.1.4.1.3375.2.2.5.3.2.1.15';
|
||||||
|
my $snmp_result = $options{snmp}->get_table(oid => $oid_status);
|
||||||
|
|
||||||
|
foreach my $oid (keys %$snmp_result) {
|
||||||
|
$oid =~ /^$oid_status\.(.*)$/;
|
||||||
|
my $instance = $1;
|
||||||
|
my @indexes = split(/\./, $1);
|
||||||
|
|
||||||
|
my $num = shift(@indexes);
|
||||||
|
my $poolInstance = $num . '.' . join('.', splice(@indexes, 0, $num));
|
||||||
|
my $nodeName = $self->{output}->decode(join('', map(chr($_), splice(@indexes, 0, shift(@indexes)) )));
|
||||||
|
my $port = $indexes[0];
|
||||||
|
|
||||||
|
next if (!defined($self->{pools}->{$poolInstance}));
|
||||||
|
|
||||||
|
$options{snmp}->load(
|
||||||
|
oids => [ map($_->{oid}, values(%{$mapping_members->{ $options{map} }})) ],
|
||||||
|
instances => [$instance],
|
||||||
|
instance_regexp => '^(.*)$'
|
||||||
|
);
|
||||||
|
|
||||||
|
$self->{pools}->{$poolInstance}->{members}->{$instance} = {
|
||||||
|
poolName => $self->{pools}->{$poolInstance}->{display},
|
||||||
|
nodeName => $nodeName,
|
||||||
|
port => $port,
|
||||||
|
status => $map_pool_status->{ $snmp_result->{$oid} }
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
$snmp_result = $options{snmp}->get_leef();
|
||||||
|
foreach (keys %$snmp_result) {
|
||||||
|
next if (! /^$mapping_members->{ $options{map} }->{state}->{oid}\.(.*)$/);
|
||||||
|
my $instance = $1;
|
||||||
|
my @indexes = split(/\./, $1);
|
||||||
|
|
||||||
|
my $num = shift(@indexes);
|
||||||
|
my $poolInstance = $num . '.' . join('.', splice(@indexes, 0, $num));
|
||||||
|
|
||||||
|
my $result = $options{snmp}->map_instance(mapping => $mapping_members->{ $options{map} }, results => $snmp_result, instance => $instance);
|
||||||
|
$result->{reason} = '-' if (!defined($result->{reason}) || $result->{reason} eq '');
|
||||||
|
|
||||||
|
if ($result->{state} ne 'disabled') {
|
||||||
|
$self->{pools}->{$poolInstance}->{pool_status}->{membersAllDisabled} = 'no';
|
||||||
|
}
|
||||||
|
|
||||||
|
$self->{pools}->{$poolInstance}->{members}->{$instance}->{state} = $result->{state};
|
||||||
|
$self->{pools}->{$poolInstance}->{members}->{$instance}->{reason} = $result->{reason};
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
sub manage_selection {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $snmp_result = $options{snmp}->get_multiple_table(
|
my ($branch_name, $map) = ($mapping->{new}->{status}->{oid}, 'new');
|
||||||
oids => [
|
my $snmp_result = $options{snmp}->get_table(oid => $mapping->{new}->{status}->{oid} );
|
||||||
{ oid => $mapping->{new}->{AvailState}->{oid} },
|
|
||||||
{ oid => $mapping->{old}->{AvailState}->{oid} },
|
if (scalar(keys %$snmp_result) == 0) {
|
||||||
],
|
($branch_name, $map) = ($mapping->{old}->{status}->{oid}, 'old');
|
||||||
|
$snmp_result = $options{snmp}->get_table(
|
||||||
|
oid => $mapping->{old}->{status}->{oid},
|
||||||
nothing_quit => 1
|
nothing_quit => 1
|
||||||
);
|
);
|
||||||
|
|
||||||
my ($branch_name, $map) = ($mapping->{new}->{AvailState}->{oid}, 'new');
|
|
||||||
if (!defined($snmp_result->{$mapping->{new}->{AvailState}->{oid}}) || scalar(keys %{$snmp_result->{$mapping->{new}->{AvailState}->{oid}}}) == 0) {
|
|
||||||
($branch_name, $map) = ($mapping->{old}->{AvailState}->{oid}, 'old');
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{pool} = {};
|
$self->{pools} = {};
|
||||||
foreach my $oid (keys %{$snmp_result->{$branch_name}}) {
|
foreach my $oid (keys %$snmp_result) {
|
||||||
$oid =~ /^$branch_name\.(.*?)\.(.*)$/;
|
$oid =~ /^$branch_name\.(.*?)\.(.*)$/;
|
||||||
my ($num, $index) = ($1, $2);
|
my ($num, $index) = ($1, $2);
|
||||||
|
|
||||||
my $result = $options{snmp}->map_instance(mapping => $mapping->{$map}, results => $snmp_result->{$branch_name}, instance => $num . '.' . $index);
|
my $result = $options{snmp}->map_instance(mapping => $mapping->{$map}, results => $snmp_result, instance => $num . '.' . $index);
|
||||||
my $name = $self->{output}->decode(join('', map(chr($_), split(/\./, $index))));
|
my $name = $self->{output}->decode(join('', map(chr($_), split(/\./, $index))));
|
||||||
|
|
||||||
if (defined($self->{option_results}->{filter_name}) && $self->{option_results}->{filter_name} ne '' &&
|
if (defined($self->{option_results}->{filter_name}) && $self->{option_results}->{filter_name} ne '' &&
|
||||||
|
@ -161,41 +265,51 @@ sub manage_selection {
|
||||||
next;
|
next;
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{pool}->{$num . '.' . $index} = {
|
$self->{pools}->{$num . '.' . $index} = {
|
||||||
display => $name,
|
display => $name,
|
||||||
status => $result->{AvailState}
|
pool_status => {
|
||||||
|
display => $name,
|
||||||
|
status => $result->{status},
|
||||||
|
membersAllDisabled => 'yes'
|
||||||
|
},
|
||||||
|
members => {}
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (scalar(keys %{$self->{pools}}) <= 0) {
|
||||||
|
$self->{output}->add_option_msg(short_msg => 'No pool found');
|
||||||
|
$self->{output}->option_exit();
|
||||||
|
}
|
||||||
|
|
||||||
$options{snmp}->load(
|
$options{snmp}->load(
|
||||||
oids => [
|
oids => [
|
||||||
$mapping->{$map}->{EnabledState}->{oid},
|
$mapping->{$map}->{state}->{oid},
|
||||||
$mapping->{$map}->{StatusReason}->{oid},
|
$mapping->{$map}->{reason}->{oid},
|
||||||
$mapping2->{ltmPoolStatServerCurConns}->{oid},
|
$mapping2->{ltmPoolStatServerCurConns}->{oid},
|
||||||
$mapping2->{ltmPoolActiveMemberCnt}->{oid},
|
$mapping2->{ltmPoolActiveMemberCnt}->{oid},
|
||||||
$mapping2->{ltmPoolMemberCnt}->{oid},
|
$mapping2->{ltmPoolMemberCnt}->{oid},
|
||||||
],
|
],
|
||||||
instances => [keys %{$self->{pool}}],
|
instances => [keys %{$self->{pools}}],
|
||||||
instance_regexp => '^(.*)$'
|
instance_regexp => '^(.*)$'
|
||||||
);
|
);
|
||||||
$snmp_result = $options{snmp}->get_leef(nothing_quit => 1);
|
$snmp_result = $options{snmp}->get_leef(nothing_quit => 1);
|
||||||
|
|
||||||
foreach (keys %{$self->{pool}}) {
|
foreach (keys %{$self->{pools}}) {
|
||||||
my $result = $options{snmp}->map_instance(mapping => $mapping->{$map}, results => $snmp_result, instance => $_);
|
my $result = $options{snmp}->map_instance(mapping => $mapping->{$map}, results => $snmp_result, instance => $_);
|
||||||
my $result2 = $options{snmp}->map_instance(mapping => $mapping2, results => $snmp_result, instance => $_);
|
my $result2 = $options{snmp}->map_instance(mapping => $mapping2, results => $snmp_result, instance => $_);
|
||||||
|
|
||||||
$result->{StatusReason} = '-' if (!defined($result->{StatusReason}) || $result->{StatusReason} eq '');
|
$result->{reason} = '-' if (!defined($result->{reason}) || $result->{reason} eq '');
|
||||||
$self->{pool}->{$_}->{reason} = $result->{StatusReason};
|
$self->{pools}->{$_}->{pool_status}->{reason} = $result->{reason};
|
||||||
$self->{pool}->{$_}->{state} = $result->{EnabledState};
|
$self->{pools}->{$_}->{pool_status}->{state} = $result->{state};
|
||||||
$self->{pool}->{$_}->{ltmPoolStatServerCurConns} = $result2->{ltmPoolStatServerCurConns};
|
$self->{pools}->{$_}->{pool_connections} = {
|
||||||
$self->{pool}->{$_}->{ltmPoolActiveMemberCnt} = $result2->{ltmPoolActiveMemberCnt};
|
display => $self->{pools}->{$_}->{display},
|
||||||
$self->{pool}->{$_}->{ltmPoolMemberCnt} = $result2->{ltmPoolMemberCnt};
|
ltmPoolStatServerCurConns => $result2->{ltmPoolStatServerCurConns},
|
||||||
|
ltmPoolActiveMemberCnt => $result2->{ltmPoolActiveMemberCnt},
|
||||||
|
ltmPoolMemberCnt => $result2->{ltmPoolMemberCnt}
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
if (scalar(keys %{$self->{pool}}) <= 0) {
|
$self->add_members(snmp => $options{snmp}, map => $map);
|
||||||
$self->{output}->add_option_msg(short_msg => "No entry found.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
@ -204,7 +318,7 @@ __END__
|
||||||
|
|
||||||
=head1 MODE
|
=head1 MODE
|
||||||
|
|
||||||
Check Pools status.
|
Check pools.
|
||||||
|
|
||||||
=over 8
|
=over 8
|
||||||
|
|
||||||
|
@ -214,18 +328,33 @@ Filter by name (regexp can be used).
|
||||||
|
|
||||||
=item B<--unknown-status>
|
=item B<--unknown-status>
|
||||||
|
|
||||||
Set unknown threshold for status (Default: '').
|
Set unknown threshold for status.
|
||||||
Can used special variables like: %{state}, %{status}, %{display}
|
Can used special variables like: %{state}, %{status}, %{membersAllDisabled}, %{display}
|
||||||
|
|
||||||
=item B<--warning-status>
|
=item B<--warning-status>
|
||||||
|
|
||||||
Set warning threshold for status (Default: '%{state} eq "enabled" and %{status} eq "yellow"').
|
Set warning threshold for status (Default: '%{membersAllDisabled} eq "no" and %{state} eq "enabled" and %{status} eq "yellow"').
|
||||||
Can used special variables like: %{state}, %{status}, %{display}
|
Can used special variables like: %{state}, %{status}, %{membersAllDisabled}, %{display}
|
||||||
|
|
||||||
=item B<--critical-status>
|
=item B<--critical-status>
|
||||||
|
|
||||||
Set critical threshold for status (Default: '%{state} eq "enabled" and %{status} eq "red"').
|
Set critical threshold for status (Default: '%{membersAllDisabled} eq "no" and %{state} eq "enabled" and %{status} eq "red"').
|
||||||
Can used special variables like: %{state}, %{status}, %{display}
|
Can used special variables like: %{state}, %{status}, %{membersAllDisabled}, %{display}
|
||||||
|
|
||||||
|
=item B<--unknown-member-status>
|
||||||
|
|
||||||
|
Set unknown threshold for status.
|
||||||
|
Can used special variables like: %{state}, %{status}, %{poolName}, %{nodeName}
|
||||||
|
|
||||||
|
=item B<--warning-member-status>
|
||||||
|
|
||||||
|
Set warning threshold for status.
|
||||||
|
Can used special variables like: %{state}, %{status}, %{poolName}, %{nodeName}
|
||||||
|
|
||||||
|
=item B<--critical-member-status>
|
||||||
|
|
||||||
|
Set critical threshold for status.
|
||||||
|
Can used special variables like: %{state}, %{status}, %{poolName}, %{nodeName}
|
||||||
|
|
||||||
=item B<--warning-*> B<--critical-*>
|
=item B<--warning-*> B<--critical-*>
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue