fix new oracle mode
This commit is contained in:
parent
c3a92b07a6
commit
4eed9edd28
|
@ -46,8 +46,9 @@ sub set_counters {
|
||||||
},
|
},
|
||||||
{ label => 'total-waits-time', set => {
|
{ label => 'total-waits-time', set => {
|
||||||
key_values => [ { name => 'time_waited_micro', diff => 1 }, { name => 'display' } ],
|
key_values => [ { name => 'time_waited_micro', diff => 1 }, { name => 'display' } ],
|
||||||
|
per_second => 1,
|
||||||
closure_custom_calc => $self->can('custom_usage_calc'),
|
closure_custom_calc => $self->can('custom_usage_calc'),
|
||||||
output_template => 'Total Waits Time : %.2f %%', output_use => 'prct_wait', threshold_use => 'prct_wait',
|
output_template => 'Total Waits Time : %.2f %%', output_use => 'prct_wait', threshold_use => 'prct_wait',
|
||||||
perfdatas => [
|
perfdatas => [
|
||||||
{ label => 'total_waits_time', value => 'prct_wait', template => '%.2f', min => 0, max => 100, unit => '%',
|
{ label => 'total_waits_time', value => 'prct_wait', template => '%.2f', min => 0, max => 100, unit => '%',
|
||||||
label_extra_instance => 1, instance_use => 'display' },
|
label_extra_instance => 1, instance_use => 'display' },
|
||||||
|
@ -131,7 +132,7 @@ sub manage_selection {
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{cache_name} = "oracle_" . $options{snmp}->get_hostname() . '_' . $options{snmp}->get_port() . '_' . $self->{mode} . '_' .
|
$self->{cache_name} = "oracle_" . $self->{mode} . '_' . $self->{sql}->get_unique_id4save() . '_' .
|
||||||
(defined($self->{option_results}->{filter_counters}) ? md5_hex($self->{option_results}->{filter_counters}) : md5_hex('all')) . '_' .
|
(defined($self->{option_results}->{filter_counters}) ? md5_hex($self->{option_results}->{filter_counters}) : md5_hex('all')) . '_' .
|
||||||
(defined($self->{option_results}->{filter_name}) ? md5_hex($self->{option_results}->{filter_name}) : md5_hex('all'));
|
(defined($self->{option_results}->{filter_name}) ? md5_hex($self->{option_results}->{filter_name}) : md5_hex('all'));
|
||||||
}
|
}
|
||||||
|
|
|
@ -89,7 +89,7 @@ sub custom_hitratio_calc {
|
||||||
|
|
||||||
my $delta_waits = $options{new_datas}->{$self->{instance} . '_waits'} - $options{old_datas}->{$self->{instance} . '_waits'};
|
my $delta_waits = $options{new_datas}->{$self->{instance} . '_waits'} - $options{old_datas}->{$self->{instance} . '_waits'};
|
||||||
my $delta_gets = $options{new_datas}->{$self->{instance} . '_gets'} - $options{old_datas}->{$self->{instance} . '_gets'};
|
my $delta_gets = $options{new_datas}->{$self->{instance} . '_gets'} - $options{old_datas}->{$self->{instance} . '_gets'};
|
||||||
$self->{result_values}->{hit_ratio} = 100 - 100 * $self->{delta_waits} / $self->{delta_gets};
|
$self->{result_values}->{hit_ratio} = $delta_gets == 0 ? 100 : (100 - 100 * $delta_waits / $delta_gets);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -99,7 +99,7 @@ sub custom_contention_calc {
|
||||||
|
|
||||||
my $delta_waits = $options{new_datas}->{$self->{instance} . '_complete'} - $options{old_datas}->{$self->{instance} . '_complete'};
|
my $delta_waits = $options{new_datas}->{$self->{instance} . '_complete'} - $options{old_datas}->{$self->{instance} . '_complete'};
|
||||||
my $delta_undo = $options{new_datas}->{$self->{instance} . '_undo' . $options{extra_options}->{label_ref}} - $options{old_datas}->{$self->{instance} . '_undo' . $options{extra_options}->{label_ref}};
|
my $delta_undo = $options{new_datas}->{$self->{instance} . '_undo' . $options{extra_options}->{label_ref}} - $options{old_datas}->{$self->{instance} . '_undo' . $options{extra_options}->{label_ref}};
|
||||||
$self->{result_values}->{$options{extra_options}->{label_ref} . '_prct'} = 100 * $delta_undo / $delta_waits;
|
$self->{result_values}->{$options{extra_options}->{label_ref} . '_prct'} = $delta_waits == 0 ? 0 : (100 * $delta_undo / $delta_waits);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -132,8 +132,8 @@ sub manage_selection {
|
||||||
};
|
};
|
||||||
|
|
||||||
$self->{sql}->query(query => $query);
|
$self->{sql}->query(query => $query);
|
||||||
my $result = $self->{sql}->fetchrow_array();
|
my @result = $self->{sql}->fetchrow_array();
|
||||||
$self->{segment} = { waits => $result->[0], gets => $result->[1], extends => $result->[2], wraps => $result->[3] };
|
$self->{segment} = { waits => $result[0], gets => $result[1], extends => $result[2], wraps => $result[3] };
|
||||||
|
|
||||||
$query = q{
|
$query = q{
|
||||||
SELECT (
|
SELECT (
|
||||||
|
@ -152,12 +152,13 @@ sub manage_selection {
|
||||||
) complete
|
) complete
|
||||||
FROM DUAL
|
FROM DUAL
|
||||||
};
|
};
|
||||||
$result = $self->{sql}->fetchrow_array();
|
$self->{sql}->query(query => $query);
|
||||||
$self->{segment}->{undoheader} = $result->[0];
|
@result = $self->{sql}->fetchrow_array();
|
||||||
$self->{segment}->{undoblock} = $result->[1];
|
$self->{segment}->{undoheader} = $result[0];
|
||||||
$self->{segment}->{complete} = $result->[2];
|
$self->{segment}->{undoblock} = $result[1];
|
||||||
|
$self->{segment}->{complete} = $result[2];
|
||||||
|
|
||||||
$self->{cache_name} = "oracle_" . $options{snmp}->get_hostname() . '_' . $options{snmp}->get_port() . '_' . $self->{mode} . '_' .
|
$self->{cache_name} = "oracle_" . $self->{mode} . '_' . $self->{sql}->get_unique_id4save() . '_' .
|
||||||
(defined($self->{option_results}->{filter_counters}) ? md5_hex($self->{option_results}->{filter_counters}) : md5_hex('all'));
|
(defined($self->{option_results}->{filter_counters}) ? md5_hex($self->{option_results}->{filter_counters}) : md5_hex('all'));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue