+ Fix vserver citrix netscaler unit

This commit is contained in:
garnier-quentin 2017-03-29 15:46:14 +02:00
parent 200c1e22f5
commit 93f9fba929
1 changed files with 6 additions and 17 deletions

View File

@ -55,7 +55,7 @@ sub set_counters {
}, },
{ label => 'in-traffic', set => { { label => 'in-traffic', set => {
key_values => [ { name => 'in', diff => 1 }, { name => 'display' } ], key_values => [ { name => 'in', diff => 1 }, { name => 'display' } ],
per_second => 1, output_change_bytes => 1, per_second => 1, output_change_bytes => 2,
output_template => 'Traffic In: %s %s/s', output_template => 'Traffic In: %s %s/s',
perfdatas => [ perfdatas => [
{ label => 'traffic_in', value => 'in_per_second', template => '%.2f', { label => 'traffic_in', value => 'in_per_second', template => '%.2f',
@ -65,7 +65,7 @@ sub set_counters {
}, },
{ label => 'out-traffic', set => { { label => 'out-traffic', set => {
key_values => [ { name => 'out', diff => 1 }, { name => 'display' } ], key_values => [ { name => 'out', diff => 1 }, { name => 'display' } ],
per_second => 1, output_change_bytes => 1, per_second => 1, output_change_bytes => 2,
output_template => 'Traffic Out: %s %s/s', output_template => 'Traffic Out: %s %s/s',
perfdatas => [ perfdatas => [
{ label => 'traffic_out', value => 'out_per_second', template => '%.2f', { label => 'traffic_out', value => 'out_per_second', template => '%.2f',
@ -73,16 +73,6 @@ sub set_counters {
], ],
} }
}, },
{ label => 'in-traffic', set => {
key_values => [ { name => 'in', diff => 1 }, { name => 'display' } ],
per_second => 1, output_change_bytes => 1,
output_template => 'Traffic In: %s %s/s',
perfdatas => [
{ label => 'traffic_in', value => 'in_per_second', template => '%.2f',
min => 0, unit => 'b/s', label_extra_instance => 1, instance_use => 'display_absolute' },
],
}
},
{ label => 'clients', set => { { label => 'clients', set => {
key_values => [ { name => 'clients', diff => 1 }, { name => 'display' } ], key_values => [ { name => 'clients', diff => 1 }, { name => 'display' } ],
output_template => 'Total Client Connections : %s', output_template => 'Total Client Connections : %s',
@ -218,10 +208,10 @@ my %map_vs_status = (
my $mapping = { my $mapping = {
vsvrName => { oid => '.1.3.6.1.4.1.5951.4.1.3.1.1.1' }, vsvrName => { oid => '.1.3.6.1.4.1.5951.4.1.3.1.1.1' },
vsvrState => { oid => '.1.3.6.1.4.1.5951.4.1.3.1.1.5', map => \%map_vs_status },
vsvrEntityType => { oid => '.1.3.6.1.4.1.5951.4.1.3.1.1.64', map => \%map_vs_type }, vsvrEntityType => { oid => '.1.3.6.1.4.1.5951.4.1.3.1.1.64', map => \%map_vs_type },
}; };
my $mapping2 = { my $mapping2 = {
vsvrState => { oid => '.1.3.6.1.4.1.5951.4.1.3.1.1.5', map => \%map_vs_status },
vsvrTotalRequestBytesLow => { oid => '.1.3.6.1.4.1.5951.4.1.3.1.1.13' }, vsvrTotalRequestBytesLow => { oid => '.1.3.6.1.4.1.5951.4.1.3.1.1.13' },
vsvrTotalRequestBytesHigh => { oid => '.1.3.6.1.4.1.5951.4.1.3.1.1.14' }, vsvrTotalRequestBytesHigh => { oid => '.1.3.6.1.4.1.5951.4.1.3.1.1.14' },
vsvrTotalResponseBytesLow => { oid => '.1.3.6.1.4.1.5951.4.1.3.1.1.17' }, vsvrTotalResponseBytesLow => { oid => '.1.3.6.1.4.1.5951.4.1.3.1.1.17' },
@ -238,6 +228,7 @@ sub manage_selection {
my $snmp_result = $options{snmp}->get_multiple_table(oids => [ my $snmp_result = $options{snmp}->get_multiple_table(oids => [
{ oid => $mapping->{vsvrName}->{oid} }, { oid => $mapping->{vsvrName}->{oid} },
{ oid => $mapping->{vsvrState}->{oid} },
{ oid => $mapping->{vsvrEntityType}->{oid} }, { oid => $mapping->{vsvrEntityType}->{oid} },
], return_type => 1, nothing_quit => 1); ], return_type => 1, nothing_quit => 1);
$self->{vservers} = {}; $self->{vservers} = {};
@ -257,11 +248,10 @@ sub manage_selection {
next; next;
} }
$self->{vservers}->{$instance} = { display => $result->{vsvrName} }; $self->{vservers}->{$instance} = { display => $result->{vsvrName}, state => $result->{vsvrState} };
} }
$options{snmp}->load(oids => [$mapping2->{vsvrState}->{oid}, $options{snmp}->load(oids => [$mapping2->{vsvrTotalRequestBytesLow}->{oid}, $mapping2->{vsvrTotalRequestBytesHigh}->{oid},
$mapping2->{vsvrTotalRequestBytesLow}->{oid}, $mapping2->{vsvrTotalRequestBytesHigh}->{oid},
$mapping2->{vsvrTotalResponseBytesLow}->{oid}, $mapping2->{vsvrTotalResponseBytesHigh}->{oid}, $mapping2->{vsvrTotalResponseBytesLow}->{oid}, $mapping2->{vsvrTotalResponseBytesHigh}->{oid},
$mapping2->{vsvrTotalRequestBytes}->{oid}, $mapping2->{vsvrTotalResponseBytes}->{oid}, $mapping2->{vsvrTotalRequestBytes}->{oid}, $mapping2->{vsvrTotalResponseBytes}->{oid},
$mapping2->{vsvrTotalClients}->{oid}, $mapping2->{vsvrHealth}->{oid}, $mapping2->{vsvrTotalServers}->{oid} $mapping2->{vsvrTotalClients}->{oid}, $mapping2->{vsvrHealth}->{oid}, $mapping2->{vsvrTotalServers}->{oid}
@ -277,7 +267,6 @@ sub manage_selection {
$self->{vservers}->{$_}->{out} = (defined($result->{vsvrTotalRequestBytes}) ? $result->{vsvrTotalRequestBytes} : $self->{vservers}->{$_}->{out} = (defined($result->{vsvrTotalRequestBytes}) ? $result->{vsvrTotalRequestBytes} :
(($result->{vsvrTotalRequestBytesHigh} << 32) + $result->{vsvrTotalRequestBytesLow})) * 8; (($result->{vsvrTotalRequestBytesHigh} << 32) + $result->{vsvrTotalRequestBytesLow})) * 8;
$self->{vservers}->{$_}->{health} = $result->{vsvrHealth}; $self->{vservers}->{$_}->{health} = $result->{vsvrHealth};
$self->{vservers}->{$_}->{state} = $result->{vsvrState};
$self->{vservers}->{$_}->{clients} = $result->{vsvrTotalClients}; $self->{vservers}->{$_}->{clients} = $result->{vsvrTotalClients};
$self->{vservers}->{$_}->{servers} = $result->{vsvrTotalServers}; $self->{vservers}->{$_}->{servers} = $result->{vsvrTotalServers};
} }