+ alcatel is so slow!! optimize the check
This commit is contained in:
parent
dc2d950b29
commit
bb70a05d30
|
@ -39,7 +39,9 @@ my $oid_sfpDiagEntry = '.1.3.6.1.4.1.637.61.1.56.5.1';
|
||||||
sub load {
|
sub load {
|
||||||
my ($self) = @_;
|
my ($self) = @_;
|
||||||
|
|
||||||
push @{$self->{request}}, { oid => $oid_sfpDiagEntry, start => $mapping->{sfpDiagLOS}->{oid}, end => $mapping->{sfpDiagTemperature}->{oid}, };
|
foreach (keys %$mapping) {
|
||||||
|
push @{$self->{request}}, { oid => $mapping->{$_}->{oid} };
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
sub check {
|
sub check {
|
||||||
|
@ -49,6 +51,11 @@ sub check {
|
||||||
$self->{components}->{sfp} = {name => 'sfp', total => 0, skip => 0};
|
$self->{components}->{sfp} = {name => 'sfp', total => 0, skip => 0};
|
||||||
return if ($self->check_filter(section => 'sfp'));
|
return if ($self->check_filter(section => 'sfp'));
|
||||||
|
|
||||||
|
my $results = {};
|
||||||
|
foreach (keys %$mapping) {
|
||||||
|
$results = { %$results, %{$self->{results}->{$mapping->{$_}->{oid}}} };
|
||||||
|
}
|
||||||
|
|
||||||
my ($exit, $warn, $crit, $checked);
|
my ($exit, $warn, $crit, $checked);
|
||||||
foreach my $oid ($self->{snmp}->oid_lex_sort(keys %{$self->{results}->{$oid_sfpDiagEntry}})) {
|
foreach my $oid ($self->{snmp}->oid_lex_sort(keys %{$self->{results}->{$oid_sfpDiagEntry}})) {
|
||||||
next if ($oid !~ /^$mapping->{sfpDiagLOS}->{oid}\.(.*?)\.(.*?)$/);
|
next if ($oid !~ /^$mapping->{sfpDiagLOS}->{oid}\.(.*?)\.(.*?)$/);
|
||||||
|
@ -56,7 +63,7 @@ sub check {
|
||||||
|
|
||||||
my $result = $self->{snmp}->map_instance(mapping => $mapping_slot, results =>
|
my $result = $self->{snmp}->map_instance(mapping => $mapping_slot, results =>
|
||||||
{ %{$self->{results}->{$mapping_slot->{eqptSlotActualType}->{oid}}}, %{$self->{results}->{$mapping_slot->{eqptBoardInventorySerialNumber}->{oid}}} }, instance => $slot_id);
|
{ %{$self->{results}->{$mapping_slot->{eqptSlotActualType}->{oid}}}, %{$self->{results}->{$mapping_slot->{eqptBoardInventorySerialNumber}->{oid}}} }, instance => $slot_id);
|
||||||
my $result2 = $self->{snmp}->map_instance(mapping => $mapping, results => $self->{results}->{$oid_sfpDiagEntry}, instance => $slot_id . '.' . $sfp_faceplate_num);
|
my $result2 = $self->{snmp}->map_instance(mapping => $mapping, results => $results, instance => $slot_id . '.' . $sfp_faceplate_num);
|
||||||
|
|
||||||
next if ($self->check_filter(section => 'sfp', instance => $slot_id . '.' . $sfp_faceplate_num));
|
next if ($self->check_filter(section => 'sfp', instance => $slot_id . '.' . $sfp_faceplate_num));
|
||||||
|
|
||||||
|
|
|
@ -85,8 +85,8 @@ Can be: 'cardtemperature', 'sfp'.
|
||||||
|
|
||||||
=item B<--filter>
|
=item B<--filter>
|
||||||
|
|
||||||
Exclude some parts (comma seperated list) (Example: --filter=fan --filter=psu)
|
Exclude some parts (comma seperated list) (Example: --filter=cardtemperature)
|
||||||
Can also exclude specific instance: --filter=fan,101
|
Can also exclude specific instance: --filter=cardtemperature,1080.1
|
||||||
|
|
||||||
=item B<--no-component>
|
=item B<--no-component>
|
||||||
|
|
||||||
|
@ -101,13 +101,13 @@ Example: --threshold-overload='psu,CRITICAL,^(?!(presentOK)$)'
|
||||||
|
|
||||||
=item B<--warning>
|
=item B<--warning>
|
||||||
|
|
||||||
Set warning threshold for 'temperature', 'fan', 'psu.fan', 'psu' (syntax: type,regexp,threshold)
|
Set warning threshold for 'sfp.temperature', 'cardtemperature' (syntax: type,regexp,threshold)
|
||||||
Example: --warning='psu.fan,1.1,5000'
|
Example: --warning='sfp.temperature,1.1,30'
|
||||||
|
|
||||||
=item B<--critical>
|
=item B<--critical>
|
||||||
|
|
||||||
Set critical threshold for 'temperature', 'fan', 'psu.fan', 'psu' (syntax: type,regexp,threshold)
|
Set critical threshold for 'sfp.temperature', 'cardtemperature' (syntax: type,regexp,threshold)
|
||||||
Example: --critical='psu,.*,200'
|
Example: --warning='sfp.temperature,1.1,40'
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue