(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:
qgarnier 2022-10-03 16:25:27 +02:00 committed by GitHub
parent b78b99cc36
commit 2122a54e74
1 changed files with 201 additions and 72 deletions

View File

@ -29,71 +29,114 @@ use centreon::plugins::templates::catalog_functions qw(catalog_status_threshold_
sub custom_status_output {
my ($self, %options) = @_;
my $msg = sprintf(
return sprintf(
'status: %s [state: %s] [reason: %s]',
$self->{result_values}->{status},
$self->{result_values}->{state},
$self->{result_values}->{reason}
);
return $msg;
}
sub pool_long_output {
my ($self, %options) = @_;
return "checking pool '" . $options{instance_value}->{display} . "'";
}
sub prefix_pool_output {
my ($self, %options) = @_;
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 => 'pool', type => 1, cb_prefix_output => 'prefix_pool_output', message_multiple => 'All Pools are ok', skipped_code => { -10 => 1 } }
{ 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} = [
$self->{maps_counters}->{pool_status} = [
{
label => 'status', type => 2, warning_default => '%{state} eq "enabled" and %{status} eq "yellow"', critical_default => '%{state} eq "enabled" and %{status} eq "red"',
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 => 'reason' },{ name => 'display' } ],
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
}
},
{ label => 'current-server-connections', set => {
}
];
$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 => [
{ label => 'current_server_connections', template => '%s',
min => 0, label_extra_instance => 1, instance_use => 'display' }
{ template => '%s', min => 0, label_extra_instance => 1, instance_use => 'display' }
]
}
},
{ label => 'current-active-members', display_ok => 0, set => {
{ label => 'current-active-members', nlabel => 'pool.members.active.count', 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' }
{ template => '%s', min => 0, label_extra_instance => 1, instance_use => 'display' }
]
}
},
{ label => 'current-total-members', display_ok => 0, set => {
{ 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 => [
{ label => 'current_total_members', template => '%s',
min => 0, label_extra_instance => 1, instance_use => 'display' }
{ 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 prefix_pool_output {
my ($self, %options) = @_;
return "Pool '" . $options{instance_value}->{display} . "' ";
}
sub new {
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;
$options{options}->add_options(arguments => {
@ -115,15 +158,25 @@ my $map_pool_enabled = {
# New OIDS
my $mapping = {
new => {
AvailState => { oid => '.1.3.6.1.4.1.3375.2.2.5.5.2.1.2', map => $map_pool_status },
EnabledState => { oid => '.1.3.6.1.4.1.3375.2.2.5.5.2.1.3', map => $map_pool_enabled },
StatusReason => { oid => '.1.3.6.1.4.1.3375.2.2.5.5.2.1.5' }
status => { oid => '.1.3.6.1.4.1.3375.2.2.5.5.2.1.2', map => $map_pool_status }, # AvailState
state => { oid => '.1.3.6.1.4.1.3375.2.2.5.5.2.1.3', map => $map_pool_enabled }, # EnabledState
reason => { oid => '.1.3.6.1.4.1.3375.2.2.5.5.2.1.5' } # StatusReason
},
old => {
AvailState => { oid => '.1.3.6.1.4.1.3375.2.2.5.1.2.1.18', map => $map_pool_status },
EnabledState => { oid => '.1.3.6.1.4.1.3375.2.2.5.1.2.1.19', map => $map_pool_enabled },
StatusReason => { oid => '.1.3.6.1.4.1.3375.2.2.5.1.2.1.21' }
status => { oid => '.1.3.6.1.4.1.3375.2.2.5.1.2.1.18', map => $map_pool_status }, # AvailState
state => { oid => '.1.3.6.1.4.1.3375.2.2.5.1.2.1.19', map => $map_pool_enabled }, # EnabledState
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 = {
ltmPoolStatServerCurConns => { oid => '.1.3.6.1.4.1.3375.2.2.5.2.3.1.8' },
@ -131,71 +184,132 @@ my $mapping2 = {
ltmPoolMemberCnt => { oid => '.1.3.6.1.4.1.3375.2.2.5.1.2.1.23' }
};
sub manage_selection {
sub add_members {
my ($self, %options) = @_;
my $snmp_result = $options{snmp}->get_multiple_table(
oids => [
{ oid => $mapping->{new}->{AvailState}->{oid} },
{ oid => $mapping->{old}->{AvailState}->{oid} },
],
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');
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} }
};
}
$self->{pool} = {};
foreach my $oid (keys %{$snmp_result->{$branch_name}}) {
$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 {
my ($self, %options) = @_;
my ($branch_name, $map) = ($mapping->{new}->{status}->{oid}, 'new');
my $snmp_result = $options{snmp}->get_table(oid => $mapping->{new}->{status}->{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
);
}
$self->{pools} = {};
foreach my $oid (keys %$snmp_result) {
$oid =~ /^$branch_name\.(.*?)\.(.*)$/;
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))));
if (defined($self->{option_results}->{filter_name}) && $self->{option_results}->{filter_name} ne '' &&
$name !~ /$self->{option_results}->{filter_name}/) {
$self->{output}->output_add(long_msg => "skipping pool '" . $name . "'.", debug => 1);
next;
}
$self->{pool}->{$num . '.' . $index} = {
$self->{pools}->{$num . '.' . $index} = {
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(
oids => [
$mapping->{$map}->{EnabledState}->{oid},
$mapping->{$map}->{StatusReason}->{oid},
$mapping->{$map}->{state}->{oid},
$mapping->{$map}->{reason}->{oid},
$mapping2->{ltmPoolStatServerCurConns}->{oid},
$mapping2->{ltmPoolActiveMemberCnt}->{oid},
$mapping2->{ltmPoolMemberCnt}->{oid},
],
instances => [keys %{$self->{pool}}],
instances => [keys %{$self->{pools}}],
instance_regexp => '^(.*)$'
);
$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 $result2 = $options{snmp}->map_instance(mapping => $mapping2, results => $snmp_result, instance => $_);
$result->{StatusReason} = '-' if (!defined($result->{StatusReason}) || $result->{StatusReason} eq '');
$self->{pool}->{$_}->{reason} = $result->{StatusReason};
$self->{pool}->{$_}->{state} = $result->{EnabledState};
$self->{pool}->{$_}->{ltmPoolStatServerCurConns} = $result2->{ltmPoolStatServerCurConns};
$self->{pool}->{$_}->{ltmPoolActiveMemberCnt} = $result2->{ltmPoolActiveMemberCnt};
$self->{pool}->{$_}->{ltmPoolMemberCnt} = $result2->{ltmPoolMemberCnt};
$result->{reason} = '-' if (!defined($result->{reason}) || $result->{reason} eq '');
$self->{pools}->{$_}->{pool_status}->{reason} = $result->{reason};
$self->{pools}->{$_}->{pool_status}->{state} = $result->{state};
$self->{pools}->{$_}->{pool_connections} = {
display => $self->{pools}->{$_}->{display},
ltmPoolStatServerCurConns => $result2->{ltmPoolStatServerCurConns},
ltmPoolActiveMemberCnt => $result2->{ltmPoolActiveMemberCnt},
ltmPoolMemberCnt => $result2->{ltmPoolMemberCnt}
};
}
if (scalar(keys %{$self->{pool}}) <= 0) {
$self->{output}->add_option_msg(short_msg => "No entry found.");
$self->{output}->option_exit();
}
$self->add_members(snmp => $options{snmp}, map => $map);
}
1;
@ -204,7 +318,7 @@ __END__
=head1 MODE
Check Pools status.
Check pools.
=over 8
@ -214,18 +328,33 @@ Filter by name (regexp can be used).
=item B<--unknown-status>
Set unknown threshold for status (Default: '').
Can used special variables like: %{state}, %{status}, %{display}
Set unknown threshold for status.
Can used special variables like: %{state}, %{status}, %{membersAllDisabled}, %{display}
=item B<--warning-status>
Set warning threshold for status (Default: '%{state} eq "enabled" and %{status} eq "yellow"').
Can used special variables like: %{state}, %{status}, %{display}
Set warning threshold for status (Default: '%{membersAllDisabled} eq "no" and %{state} eq "enabled" and %{status} eq "yellow"').
Can used special variables like: %{state}, %{status}, %{membersAllDisabled}, %{display}
=item B<--critical-status>
Set critical threshold for status (Default: '%{state} eq "enabled" and %{status} eq "red"').
Can used special variables like: %{state}, %{status}, %{display}
Set critical threshold for status (Default: '%{membersAllDisabled} eq "no" and %{state} eq "enabled" and %{status} eq "red"').
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-*>