kingdee: wip
This commit is contained in:
parent
dc246a91b8
commit
5222d5c085
|
@ -46,7 +46,6 @@ sub set_counters {
|
||||||
],
|
],
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -31,12 +31,9 @@ sub new {
|
||||||
my $self = $class->SUPER::new(package => __PACKAGE__, %options);
|
my $self = $class->SUPER::new(package => __PACKAGE__, %options);
|
||||||
bless $self, $class;
|
bless $self, $class;
|
||||||
|
|
||||||
$options{options}->add_options(arguments =>
|
$options{options}->add_options(arguments => {
|
||||||
{
|
'urlpath:s' => { name => 'url_path', default => "/easportal/tools/nagios/checkoracleversion.jsp" },
|
||||||
"urlpath:s" => { name => 'url_path', default => "/easportal/tools/nagios/checkoracleversion.jsp" },
|
'datasource:s' => { name => 'datasource' },
|
||||||
"datasource:s" => { name => 'datasource' },
|
|
||||||
"warning:s" => { name => 'warning' },
|
|
||||||
"critical:s" => { name => 'critical' },
|
|
||||||
});
|
});
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
|
@ -51,15 +48,6 @@ sub check_options {
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
$self->{option_results}->{url_path} .= "?ds=" . $self->{option_results}->{datasource};
|
$self->{option_results}->{url_path} .= "?ds=" . $self->{option_results}->{datasource};
|
||||||
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'warning', value => $self->{option_results}->{warning})) == 0) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong warning threshold '" . $self->{option_results}->{warning} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'critical', value => $self->{option_results}->{critical})) == 0) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong critical threshold '" . $self->{option_results}->{critical} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub run {
|
sub run {
|
||||||
|
@ -67,17 +55,14 @@ sub run {
|
||||||
|
|
||||||
my $webcontent = $options{custom}->request(path => $self->{option_results}->{url_path});
|
my $webcontent = $options{custom}->request(path => $self->{option_results}->{url_path});
|
||||||
if ($webcontent !~ /^BANNER=/i) {
|
if ($webcontent !~ /^BANNER=/i) {
|
||||||
$self->{output}->output_add(
|
$self->{output}->add_option_msg(short_msg => 'Cannot find oracle version info.');
|
||||||
severity => 'UNKNOWN',
|
|
||||||
short_msg => "Cannot find oracle version info."
|
|
||||||
);
|
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
my $banner = $1 if $webcontent =~ /^BANNER=\'(.*?)\'/i;
|
my $banner = '';
|
||||||
|
$banner = $1 if ($webcontent =~ /^BANNER=\'(.*?)\'/i);
|
||||||
|
|
||||||
$self->{output}->output_add(severity => "ok", short_msg => $banner);
|
$self->{output}->output_add(severity => "ok", short_msg => $banner);
|
||||||
|
|
||||||
$self->{output}->display();
|
$self->{output}->display();
|
||||||
$self->{output}->exit();
|
$self->{output}->exit();
|
||||||
|
|
||||||
|
@ -101,14 +86,6 @@ Set path to get status page. (Default: '/easportal/tools/nagios/checkoracleversi
|
||||||
|
|
||||||
Specify the datasource name.
|
Specify the datasource name.
|
||||||
|
|
||||||
=item B<--warning>
|
|
||||||
|
|
||||||
Warning Threshold.
|
|
||||||
|
|
||||||
=item B<--critical>
|
|
||||||
|
|
||||||
Critical Threshold.
|
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
=cut
|
=cut
|
||||||
|
|
|
@ -21,224 +21,134 @@
|
||||||
|
|
||||||
package apps::kingdee::eas::mode::ormrpc;
|
package apps::kingdee::eas::mode::ormrpc;
|
||||||
|
|
||||||
use base qw(centreon::plugins::mode);
|
use base qw(centreon::plugins::templates::counter);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
|
|
||||||
|
sub set_counters {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
$self->{maps_counters_type} = [
|
||||||
|
{ name => 'global', type => 0, cb_prefix_output => 'prefix_global_output', skipped_code => { -10 => 1 } },
|
||||||
|
];
|
||||||
|
|
||||||
|
$self->{maps_counters}->{global} = [
|
||||||
|
{ label => 'threads-active', nlabel => 'ormrpc.threads.active.count', set => {
|
||||||
|
key_values => [ { name => 'active_thread_count' } ],
|
||||||
|
output_template => 'threads active: %s',
|
||||||
|
perfdatas => [
|
||||||
|
{ value => 'active_thread_count_absolute', template => '%s', min => 0 },
|
||||||
|
],
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{ label => 'stubs', nlabel => 'ormrpc.stubs.count', display_ok => 0, set => {
|
||||||
|
key_values => [ { name => 'stub_count' } ],
|
||||||
|
output_template => 'stubs: %s',
|
||||||
|
perfdatas => [
|
||||||
|
{ value => 'stub_count_absolute', template => '%s', min => 0 },
|
||||||
|
],
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{ label => 'proxies', nlabel => 'ormrpc.proxies.count', display_ok => 0, set => {
|
||||||
|
key_values => [ { name => 'proxy_count' } ],
|
||||||
|
output_template => 'proxies: %s',
|
||||||
|
perfdatas => [
|
||||||
|
{ value => 'proxy_count_absolute', template => '%s', min => 0 },
|
||||||
|
],
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{ label => 'sessions-client', nlabel => 'ormrpc.sessions.client.count', set => {
|
||||||
|
key_values => [ { name => 'client_session_count' } ],
|
||||||
|
output_template => 'sessions client: %s',
|
||||||
|
perfdatas => [
|
||||||
|
{ value => 'client_session_count_absolute', template => '%s', min => 0 },
|
||||||
|
],
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{ label => 'sessions-server', nlabel => 'ormrpc.sessions.server.count', set => {
|
||||||
|
key_values => [ { name => 'server_session_count' } ],
|
||||||
|
output_template => 'sessions server: %s',
|
||||||
|
perfdatas => [
|
||||||
|
{ value => 'server_session_count_absolute', template => '%s', min => 0 },
|
||||||
|
],
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{ label => 'clients-invoke-perminute', nlabel => 'ormrpc.clients.invoked.countperminute', display_ok => 0, set => {
|
||||||
|
key_values => [ { name => 'client_invoke_count_per_minute' } ],
|
||||||
|
output_template => 'clients invoke: %s/m',
|
||||||
|
perfdatas => [
|
||||||
|
{ value => 'client_invoke_count_per_minute_absolute', template => '%s', min => 0, unit => '/m' },
|
||||||
|
],
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{ label => 'processed-service-perminute', nlabel => 'ormrpc.processed.service.countperminute', display_ok => 0, set => {
|
||||||
|
key_values => [ { name => 'processed_service_count_per_minute' } ],
|
||||||
|
output_template => 'processed service: %s/m',
|
||||||
|
perfdatas => [
|
||||||
|
{ value => 'processed_service_count_per_minute_absolute', template => '%s', min => 0, unit => '/m' },
|
||||||
|
],
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{ label => 'clients-invoked', nlabel => 'ormrpc.clients.invoked.count', display_ok => 0, set => {
|
||||||
|
key_values => [ { name => 'client_invoke_count', diff => 1 } ],
|
||||||
|
output_template => 'clients invoked: %s',
|
||||||
|
perfdatas => [
|
||||||
|
{ value => 'client_invoke_count_absolute', template => '%s', min => 0 },
|
||||||
|
],
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{ label => 'processed-service', nlabel => 'ormrpc.processed.service.count', display_ok => 0, set => {
|
||||||
|
key_values => [ { name => 'processed_service_count', diff => 1 } ],
|
||||||
|
output_template => 'processed service: %s',
|
||||||
|
perfdatas => [
|
||||||
|
{ value => 'processed_service_count', template => '%s', min => 0 },
|
||||||
|
],
|
||||||
|
}
|
||||||
|
},
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
sub prefix_global_output {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
return 'orm rpc ';
|
||||||
|
}
|
||||||
|
|
||||||
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, statefile => 1, force_new_perfdata => 1);
|
||||||
bless $self, $class;
|
bless $self, $class;
|
||||||
|
|
||||||
$options{options}->add_options(
|
$options{options}->add_options( arguments => {
|
||||||
arguments => {
|
|
||||||
'urlpath:s' => { name => 'url_path', default => "/easportal/tools/nagios/checkrpc.jsp" },
|
'urlpath:s' => { name => 'url_path', default => "/easportal/tools/nagios/checkrpc.jsp" },
|
||||||
'warning:s' => { name => 'warning' , default => ",,,,,,"},
|
});
|
||||||
'critical:s' => { name => 'critical' , default => ",,,,,,"},
|
|
||||||
}
|
|
||||||
);
|
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
sub check_options {
|
sub manage_selection {
|
||||||
my ( $self, %options ) = @_;
|
my ($self, %options) = @_;
|
||||||
$self->SUPER::init(%options);
|
|
||||||
|
|
||||||
($self->{warn_activethreadcount}, $self->{warn_stubcount}, $self->{warn_proxycount}, $self->{warn_clientsessioncount} ,$self->{warn_serversessioncount} ,$self->{warn_invokecountpermin} ,$self->{warn_servicecountpermin})
|
|
||||||
= split /,/, $self->{option_results}->{"warning"};
|
|
||||||
($self->{crit_activethreadcount}, $self->{crit_stubcount}, $self->{crit_proxycount}, $self->{crit_clientsessioncount} ,$self->{crit_serversessioncount} ,$self->{crit_invokecountpermin} ,$self->{crit_servicecountpermin})
|
|
||||||
= split /,/, $self->{option_results}->{"critical"};
|
|
||||||
|
|
||||||
# warning
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'warn_activethreadcount', value => $self->{warn_activethreadcount})) == 0) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong warning activethreadcount threshold '" . $self->{warn_activethreadcount} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'warn_stubcount', value => $self->{warn_stubcount})) == 0) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong warning stubcount threshold '" . $self->{warn_stubcount} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'warn_proxycount', value => $self->{warn_proxycount})) == 0) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong warning proxycount threshold '" . $self->{warn_proxycount} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'warn_clientsessioncount', value => $self->{warn_clientsessioncount})) == 0) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong warning clientsessioncount threshold '" . $self->{warn_clientsessioncount} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'warn_serversessioncount', value => $self->{warn_serversessioncount})) == 0) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong warning serversessioncount threshold '" . $self->{warn_serversessioncount} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'warn_invokecountpermin', value => $self->{warn_invokecountpermin})) == 0) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong warning invokecountpermin threshold '" . $self->{warn_invokecountpermin} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'warn_servicecountpermin', value => $self->{warn_servicecountpermin})) == 0) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong warning servicecountpermin threshold '" . $self->{warn_servicecountpermin} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
|
|
||||||
# critical
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'crit_activethreadcount', value => $self->{crit_activethreadcount})) == 0) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong critical activethreadcount threshold '" . $self->{crit_activethreadcount} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'crit_stubcount', value => $self->{crit_stubcount})) == 0) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong critical stubcount threshold '" . $self->{crit_stubcount} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'crit_proxycount', value => $self->{crit_proxycount})) == 0) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong critical proxycount threshold '" . $self->{crit_proxycount} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'crit_clientsessioncount', value => $self->{crit_clientsessioncount})) == 0) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong critical clientsessioncount threshold '" . $self->{crit_clientsessioncount} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'crit_serversessioncount', value => $self->{crit_serversessioncount})) == 0) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong critical serversessioncount threshold '" . $self->{crit_serversessioncount} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'crit_invokecountpermin', value => $self->{crit_invokecountpermin})) == 0) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong critical invokecountpermin threshold '" . $self->{crit_invokecountpermin} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'crit_servicecountpermin', value => $self->{crit_servicecountpermin})) == 0) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong critical servicecountpermin threshold '" . $self->{crit_servicecountpermin} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
sub run {
|
|
||||||
my ( $self, %options ) = @_;
|
|
||||||
|
|
||||||
my $webcontent = $options{custom}->request(path => $self->{option_results}->{url_path});
|
my $webcontent = $options{custom}->request(path => $self->{option_results}->{url_path});
|
||||||
if ($webcontent !~ /ActiveThreadCount=\d+/i) {
|
if ($webcontent !~ /ActiveThreadCount=\d+/i) {
|
||||||
$self->{output}->output_add(
|
$self->{output}->add_option_msg(short_msg => 'Cannot find ormrpc status');
|
||||||
severity => 'UNKNOWN',
|
|
||||||
short_msg => "Cannot find ormrpc status in response: \'" . $webcontent . "\'"
|
|
||||||
);
|
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
|
|
||||||
my ($activethreadcount, $stubcount, $proxycount, $clientsessioncount, $serversessioncount, $invokecountpermin, $servicecountpermin, $invokecount, $servicecount) = (0, 0, 0, 0, 0, 0, 0, 0, 0);
|
$self->{global} = {};
|
||||||
|
$self->{global}->{active_thread_count} = $1 if ($webcontent =~ /ActiveThreadCount=(\d+)/mi);
|
||||||
|
$self->{global}->{stub_count} = $1 if ($webcontent =~ /StubCount=(\d+)/mi);
|
||||||
|
$self->{global}->{proxy_count} = $1 if ($webcontent =~ /ProxyCount=(\d+)/mi);
|
||||||
|
$self->{global}->{client_session_count} = $1 if ($webcontent =~ /ClientSessionCount=(\d+)/mi);
|
||||||
|
$self->{global}->{server_session_count} = $1 if ($webcontent =~ /ServerSessionCount=(\d+)/mi);
|
||||||
|
$self->{global}->{client_invoke_count_per_minute} = $1 if ($webcontent =~ /ClientInvokeCountPerMinute=(\d+)/mi);
|
||||||
|
$self->{global}->{processed_service_count_per_minute} = $1 if ($webcontent =~ /ProcessedServiceCountPerMinute=(\d+)/mi);
|
||||||
|
$self->{global}->{client_invoke_count} = $1 if ($webcontent =~ /ClientInvokeCount=(\d+)/mi);
|
||||||
|
$self->{global}->{processed_service_count} = $1 if ($webcontent =~ /ProcessedServiceCount=(\d+)/mi);
|
||||||
|
|
||||||
$activethreadcount = $1 if $webcontent =~ /ActiveThreadCount=(\d+)/mi ;
|
$self->{cache_name} = 'kingdee_' . $self->{mode} . '_' . $options{custom}->get_hostname() . '_' . $options{custom}->get_port() . '_' .
|
||||||
$stubcount = $1 if $webcontent =~ /StubCount=(\d+)/mi ;
|
(defined($self->{option_results}->{filter_counters}) ? md5_hex($self->{option_results}->{filter_counters}) : md5_hex('all'));
|
||||||
$proxycount = $1 if $webcontent =~ /ProxyCount=(\d+)/mi ;
|
|
||||||
$clientsessioncount = $1 if $webcontent =~ /ClientSessionCount=(\d+)/mi ;
|
|
||||||
$serversessioncount = $1 if $webcontent =~ /ServerSessionCount=(\d+)/mi ;
|
|
||||||
$invokecountpermin = $1 if $webcontent =~ /ClientInvokeCountPerMinute=(\d+)/mi ;
|
|
||||||
$servicecountpermin = $1 if $webcontent =~ /ProcessedServiceCountPerMinute=(\d+)/mi ;
|
|
||||||
$invokecount = $1 if $webcontent =~ /ClientInvokeCount=(\d+)/mi ;
|
|
||||||
$servicecount = $1 if $webcontent =~ /ProcessedServiceCount=(\d+)/mi ;
|
|
||||||
|
|
||||||
my $exit = $self->{perfdata}->threshold_check(value => $activethreadcount,
|
|
||||||
threshold => [ { label => 'crit_activethreadcount', 'exit_litteral' => 'critical' },
|
|
||||||
{ label => 'warn_activethreadcount', 'exit_litteral' => 'warning' } ]);
|
|
||||||
$self->{output}->output_add(
|
|
||||||
severity => $exit,
|
|
||||||
short_msg => sprintf("ActiveThreadCount: %d", $activethreadcount)
|
|
||||||
);
|
|
||||||
$exit = $self->{perfdata}->threshold_check(value => $stubcount,
|
|
||||||
threshold => [ { label => 'crit_stubcount', 'exit_litteral' => 'critical' },
|
|
||||||
{ label => 'warn_stubcount', 'exit_litteral' => 'warning' } ]);
|
|
||||||
$self->{output}->output_add(
|
|
||||||
severity => $exit,
|
|
||||||
short_msg => sprintf("StubCount: %d", $stubcount)
|
|
||||||
);
|
|
||||||
$exit = $self->{perfdata}->threshold_check(value => $proxycount,
|
|
||||||
threshold => [ { label => 'crit_proxycount', 'exit_litteral' => 'critical' },
|
|
||||||
{ label => 'warn_proxycount', 'exit_litteral' => 'warning' } ]);
|
|
||||||
$self->{output}->output_add(
|
|
||||||
severity => $exit,
|
|
||||||
short_msg => sprintf("ProxyCount: %d", $proxycount)
|
|
||||||
);
|
|
||||||
$exit = $self->{perfdata}->threshold_check(value => $clientsessioncount,
|
|
||||||
threshold => [ { label => 'crit_clientsessioncount', 'exit_litteral' => 'critical' },
|
|
||||||
{ label => 'warn_clientsessioncount', 'exit_litteral' => 'warning' } ]);
|
|
||||||
$self->{output}->output_add(
|
|
||||||
severity => $exit,
|
|
||||||
short_msg => sprintf("ClientSessionCount: %d", $clientsessioncount)
|
|
||||||
);
|
|
||||||
$exit = $self->{perfdata}->threshold_check(value => $serversessioncount,
|
|
||||||
threshold => [ { label => 'crit_serversessioncount', 'exit_litteral' => 'critical' },
|
|
||||||
{ label => 'warn_serversessioncount', 'exit_litteral' => 'warning' } ]);
|
|
||||||
$self->{output}->output_add(
|
|
||||||
severity => $exit,
|
|
||||||
short_msg => sprintf("ServerSessionCount: %d", $serversessioncount)
|
|
||||||
);
|
|
||||||
$exit = $self->{perfdata}->threshold_check(value => $invokecountpermin,
|
|
||||||
threshold => [ { label => 'crit_invokecountpermin', 'exit_litteral' => 'critical' },
|
|
||||||
{ label => 'warn_invokecountpermin', 'exit_litteral' => 'warning' } ]);
|
|
||||||
$self->{output}->output_add(
|
|
||||||
severity => $exit,
|
|
||||||
short_msg => sprintf("InvokeCountPerMinute: %d", $invokecountpermin)
|
|
||||||
);
|
|
||||||
$exit = $self->{perfdata}->threshold_check(value => $servicecountpermin,
|
|
||||||
threshold => [ { label => 'crit_servicecountpermin', 'exit_litteral' => 'critical' },
|
|
||||||
{ label => 'warn_servicecountpermin', 'exit_litteral' => 'warning' } ]);
|
|
||||||
$self->{output}->output_add(
|
|
||||||
severity => $exit,
|
|
||||||
short_msg => sprintf("ServiceCountPerMinute: %d", $servicecountpermin)
|
|
||||||
);
|
|
||||||
|
|
||||||
$self->{output}->perfdata_add(
|
|
||||||
label => "ActiveThreadCount",
|
|
||||||
value => $activethreadcount,
|
|
||||||
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warn_activethreadcount'),
|
|
||||||
critical => $self->{perfdata}->get_perfdata_for_output(label => 'crit_activethreadcount'),
|
|
||||||
);
|
|
||||||
$self->{output}->perfdata_add(
|
|
||||||
label => "StubCount",
|
|
||||||
value => $stubcount,
|
|
||||||
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warn_stubcount'),
|
|
||||||
critical => $self->{perfdata}->get_perfdata_for_output(label => 'crit_stubcount'),
|
|
||||||
);
|
|
||||||
$self->{output}->perfdata_add(
|
|
||||||
label => "ProxyCount",
|
|
||||||
value => $proxycount,
|
|
||||||
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warn_proxycount'),
|
|
||||||
critical => $self->{perfdata}->get_perfdata_for_output(label => 'crit_proxycount'),
|
|
||||||
);
|
|
||||||
$self->{output}->perfdata_add(
|
|
||||||
label => "ClientSessionCount",
|
|
||||||
value => $clientsessioncount,
|
|
||||||
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warn_clientsessioncount'),
|
|
||||||
critical => $self->{perfdata}->get_perfdata_for_output(label => 'crit_clientsessioncount'),
|
|
||||||
);
|
|
||||||
$self->{output}->perfdata_add(
|
|
||||||
label => "ServerSessionCount",
|
|
||||||
value => $serversessioncount,
|
|
||||||
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warn_serversessioncount'),
|
|
||||||
critical => $self->{perfdata}->get_perfdata_for_output(label => 'crit_serversessioncount'),
|
|
||||||
);
|
|
||||||
$self->{output}->perfdata_add(
|
|
||||||
label => "InvokeCountPerMinute",
|
|
||||||
value => $invokecountpermin,
|
|
||||||
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warn_invokecountpermin'),
|
|
||||||
critical => $self->{perfdata}->get_perfdata_for_output(label => 'crit_invokecountpermin'),
|
|
||||||
);
|
|
||||||
$self->{output}->perfdata_add(
|
|
||||||
label => "ServiceCountPerMinute",
|
|
||||||
value => $servicecountpermin,
|
|
||||||
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warn_servicecountpermin'),
|
|
||||||
critical => $self->{perfdata}->get_perfdata_for_output(label => 'crit_servicecountpermin'),
|
|
||||||
);
|
|
||||||
$self->{output}->perfdata_add(
|
|
||||||
label => "c[InvokeCount]",
|
|
||||||
value => $invokecount,
|
|
||||||
);
|
|
||||||
$self->{output}->perfdata_add(
|
|
||||||
label => "c[ServiceCount]",
|
|
||||||
value => $servicecount,
|
|
||||||
);
|
|
||||||
|
|
||||||
$self->{output}->display();
|
|
||||||
$self->{output}->exit();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
@ -255,13 +165,12 @@ Check EAS instance orm rpc status.
|
||||||
|
|
||||||
Set path to get status page. (Default: '/easportal/tools/nagios/checkrpc.jsp')
|
Set path to get status page. (Default: '/easportal/tools/nagios/checkrpc.jsp')
|
||||||
|
|
||||||
=item B<--warning>
|
=item B<--warning-*> B<--critical-*>
|
||||||
|
|
||||||
Warning Threshold (activethreadcount,stubcount,proxycount,clientsessioncount,serversessioncount,invokecountpermin,servicecountpermin).
|
Thresholds.
|
||||||
|
Can be: 'threads-active', 'stubs', 'proxies', 'sessions-client',
|
||||||
=item B<--critical>
|
'sessions-server', 'clients-invoke-perminute', 'processed-service-perminute',
|
||||||
|
'clients-invoked', 'processed-service'.
|
||||||
Critical Threshold (activethreadcount,stubcount,proxycount,clientsessioncount,serversessioncount,invokecountpermin,servicecountpermin).
|
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
|
|
|
@ -21,125 +21,125 @@
|
||||||
|
|
||||||
package apps::kingdee::eas::mode::transaction;
|
package apps::kingdee::eas::mode::transaction;
|
||||||
|
|
||||||
use base qw(centreon::plugins::mode);
|
use base qw(centreon::plugins::templates::counter);
|
||||||
|
|
||||||
use strict;
|
use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
|
|
||||||
|
sub set_counters {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
$self->{maps_counters_type} = [
|
||||||
|
{ name => 'global', type => 0, cb_prefix_output => 'prefix_global_output', skipped_code => { -10 => 1 } },
|
||||||
|
];
|
||||||
|
|
||||||
|
$self->{maps_counters}->{global} = [
|
||||||
|
{ label => 'active', nlabel => 'transactions.active.count', set => {
|
||||||
|
key_values => [ { name => 'active_count' } ],
|
||||||
|
output_template => 'active: %s',
|
||||||
|
perfdatas => [
|
||||||
|
{ value => 'active_count_absolute', template => '%s', min => 0 },
|
||||||
|
],
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{ label => 'timedout', nlabel => 'transactions.timedout.count', display_ok => 0, set => {
|
||||||
|
key_values => [ { name => 'timedout_count' } ],
|
||||||
|
output_template => 'timed out: %s',
|
||||||
|
perfdatas => [
|
||||||
|
{ value => 'timedout_count_absolute', template => '%s', min => 0 },
|
||||||
|
],
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{ label => 'committed', nlabel => 'transactions.committed.count', set => {
|
||||||
|
key_values => [ { name => 'committed_count', diff => 1 } ],
|
||||||
|
output_template => 'committed: %s',
|
||||||
|
perfdatas => [
|
||||||
|
{ value => 'committed_count_absolute', template => '%s', min => 0 },
|
||||||
|
],
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{ label => 'rolledback', nlabel => 'transactions.rolledback.count', set => {
|
||||||
|
key_values => [ { name => 'rolledback_count', diff => 1 } ],
|
||||||
|
output_template => 'rolledback: %s',
|
||||||
|
perfdatas => [
|
||||||
|
{ value => 'rolledback_count_absolute', template => '%s', min => 0 },
|
||||||
|
],
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{ label => 'created', nlabel => 'transactions.created.count', set => {
|
||||||
|
key_values => [ { name => 'transaction_count', diff => 1 } ],
|
||||||
|
output_template => 'created: %s',
|
||||||
|
perfdatas => [
|
||||||
|
{ value => 'transaction_count_absolute', template => '%s', min => 0 },
|
||||||
|
],
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{ label => 'time-total', nlabel => 'transactions.time.total.milliseconds', set => {
|
||||||
|
key_values => [ { name => 'total_transaction_time', diff => 1 } ],
|
||||||
|
output_template => 'total time: %s ms',
|
||||||
|
perfdatas => [
|
||||||
|
{ value => 'total_transaction_time_absolute', template => '%s', min => 0, unit => 'ms' },
|
||||||
|
],
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{ label => 'time-max', nlabel => 'transactions.time.max.milliseconds', display_ok => 0, set => {
|
||||||
|
key_values => [ { name => 'max_transaction_time', diff => 1 } ],
|
||||||
|
output_template => 'max time: %s ms',
|
||||||
|
perfdatas => [
|
||||||
|
{ value => 'max_transaction_time_absolute', template => '%s', min => 0, unit => 'ms' },
|
||||||
|
],
|
||||||
|
}
|
||||||
|
},
|
||||||
|
{ label => 'timeout-default', nlabel => 'transactions.timeout.default.count', display_ok => 0, set => {
|
||||||
|
key_values => [ { name => 'default_timeout' } ],
|
||||||
|
output_template => 'default timeout: %s',
|
||||||
|
perfdatas => [
|
||||||
|
{ value => 'default_timeout_absolute', template => '%s', min => 0 },
|
||||||
|
],
|
||||||
|
}
|
||||||
|
},
|
||||||
|
];
|
||||||
|
}
|
||||||
|
|
||||||
|
sub prefix_global_output {
|
||||||
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
|
return 'transactions ';
|
||||||
|
}
|
||||||
|
|
||||||
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, statefile => 1, force_new_perfdata => 1);
|
||||||
bless $self, $class;
|
bless $self, $class;
|
||||||
|
|
||||||
$options{options}->add_options(arguments =>
|
$options{options}->add_options(arguments => {
|
||||||
{
|
'urlpath:s' => { name => 'url_path', default => "/easportal/tools/nagios/checktransaction.jsp" },
|
||||||
"urlpath:s" => { name => 'url_path', default => "/easportal/tools/nagios/checktransaction.jsp" },
|
|
||||||
"datasource:s" => { name => 'datasource' },
|
|
||||||
"warning:s" => { name => 'warning', default => "," },
|
|
||||||
"critical:s" => { name => 'critical', default => "," },
|
|
||||||
});
|
});
|
||||||
|
|
||||||
return $self;
|
return $self;
|
||||||
}
|
}
|
||||||
|
|
||||||
sub check_options {
|
sub manage_selection {
|
||||||
my ($self, %options) = @_;
|
|
||||||
$self->SUPER::init(%options);
|
|
||||||
|
|
||||||
($self->{warn_activecount}, $self->{warn_timeoutcount})
|
|
||||||
= split /,/, $self->{option_results}->{"warning"};
|
|
||||||
($self->{crit_activecount}, $self->{crit_timeoutcount})
|
|
||||||
= split /,/, $self->{option_results}->{"critical"};
|
|
||||||
|
|
||||||
# warning
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'warn_activecount', value => $self->{warn_activecount})) == 0) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong warning activecount threshold '" . $self->{warn_activecount} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'warn_timeoutcount', value => $self->{warn_timeoutcount})) == 0) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong warning timeoutcount threshold '" . $self->{warn_timeoutcount} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
# critical
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'crit_activecount', value => $self->{crit_activecount})) == 0) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong critical activecount threshold '" . $self->{crit_activecount} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
if (($self->{perfdata}->threshold_validate(label => 'crit_timeoutcount', value => $self->{crit_timeoutcount})) == 0) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Wrong critical timeoutcount threshold '" . $self->{crit_timeoutcount} . "'.");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
sub run {
|
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
my $webcontent = $options{custom}->request(path => $self->{option_results}->{url_path});
|
my $webcontent = $options{custom}->request(path => $self->{option_results}->{url_path});
|
||||||
if ($webcontent !~ /TransactionCount=\d+/i) {
|
if ($webcontent !~ /TransactionCount=\d+/i) {
|
||||||
$self->{output}->output_add(
|
$self->{output}->add_option_msg(short_msg => 'Cannot find transaction status.');
|
||||||
severity => 'UNKNOWN',
|
$self->{output}->option_exit();
|
||||||
short_msg => "Cannot find transaction status."
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
my ($transactioncount, $totaltransactiontime, $committedcount, $rolledbackcount, $activecount, $maxtransactiontime, $defaulttimeout, $timeoutcount) = (0, 0, 0, 0, 0, 0, 0, 0);
|
$self->{global} = {};
|
||||||
|
$self->{global}->{transaction_count} = $1 if ($webcontent =~ /TransactionCount=(\d+)\s/i);
|
||||||
|
$self->{global}->{total_transaction_time} = $1 if ($webcontent =~ /TotalTransactionTime=(\d+)\s/i);
|
||||||
|
$self->{global}->{committed_count} = $1 if ($webcontent =~ /CommittedCount=(\d+)\s/i);
|
||||||
|
$self->{global}->{rolledback_count} = $1 if ($webcontent =~ /RolledbackCount=(\d+)\s/i);
|
||||||
|
$self->{global}->{active_count} = $1 if ($webcontent =~ /ActiveCount=(\d+)\s/i);
|
||||||
|
$self->{global}->{max_transaction_time} = $1 if ($webcontent =~ /MaxTransactionTime=(\d+)\s/i);
|
||||||
|
$self->{global}->{default_timeout} = $1 if ($webcontent =~ /DefaultTimeout=(\d+)\s/i);
|
||||||
|
$self->{global}->{timedout_count} = $1 if ($webcontent =~ /TimedOutCount=(\d+)\s/i);
|
||||||
|
|
||||||
$transactioncount = $1 if $webcontent =~ /TransactionCount=(\d+)\s/i;
|
$self->{cache_name} = 'kingdee_' . $self->{mode} . '_' . $options{custom}->get_hostname() . '_' . $options{custom}->get_port() . '_' .
|
||||||
$totaltransactiontime = $1 if $webcontent =~ /TotalTransactionTime=(\d+)\s/i;
|
(defined($self->{option_results}->{filter_counters}) ? md5_hex($self->{option_results}->{filter_counters}) : md5_hex('all'));
|
||||||
$committedcount = $1 if $webcontent =~ /CommittedCount=(\d+)\s/i;
|
|
||||||
$rolledbackcount = $1 if $webcontent =~ /RolledbackCount=(\d+)\s/i;
|
|
||||||
$activecount = $1 if $webcontent =~ /ActiveCount=(\d+)\s/i;
|
|
||||||
$maxtransactiontime = $1 if $webcontent =~ /MaxTransactionTime=(\d+)\s/i;
|
|
||||||
$defaulttimeout = $1 if $webcontent =~ /DefaultTimeout=(\d+)\s/i;
|
|
||||||
$timeoutcount = $1 if $webcontent =~ /TimedOutCount=(\d+)\s/i;
|
|
||||||
|
|
||||||
my $exit = $self->{perfdata}->threshold_check(value => $activecount, threshold => [ { label => 'crit_activecount', exit_litteral => 'critical' },
|
|
||||||
{ label => 'warn_activecount', exit_litteral => 'warning' } ]);
|
|
||||||
$self->{output}->output_add(severity => $exit, short_msg => sprintf("ActiveCount: %d", $activecount));
|
|
||||||
|
|
||||||
$exit = $self->{perfdata}->threshold_check(value => $timeoutcount, threshold => [ { label => 'crit_timeoutcount', exit_litteral => 'critical' },
|
|
||||||
{ label => 'warn_timeoutcount', exit_litteral => 'warning' } ]);
|
|
||||||
$self->{output}->output_add(severity => $exit, short_msg => sprintf("TimedOutCount: %d", $timeoutcount));
|
|
||||||
|
|
||||||
$self->{output}->output_add(severity => "ok", short_msg => sprintf("CommittedCount: %d", $committedcount));
|
|
||||||
$self->{output}->output_add(severity => "ok", short_msg => sprintf("RolledbackCount: %d", $rolledbackcount));
|
|
||||||
$self->{output}->output_add(severity => "ok", short_msg => sprintf("TransactionCount: %d", $transactioncount));
|
|
||||||
$self->{output}->output_add(severity => "ok", short_msg => sprintf("TotalTransactionTime: %dms", $totaltransactiontime));
|
|
||||||
$self->{output}->output_add(severity => "ok", short_msg => sprintf("MaxTransactionTime: %dms", $maxtransactiontime));
|
|
||||||
$self->{output}->output_add(severity => "ok", short_msg => sprintf("DefaultTimeout: %ds", $defaulttimeout));
|
|
||||||
|
|
||||||
|
|
||||||
$self->{output}->perfdata_add(label => "ActiveCount", unit => '',
|
|
||||||
value => sprintf("%d", $activecount),
|
|
||||||
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warn_activecount'),
|
|
||||||
critical => $self->{perfdata}->get_perfdata_for_output(label => 'crit_activecount'),
|
|
||||||
);
|
|
||||||
$self->{output}->perfdata_add(label => "TimedOutCount", unit => '',
|
|
||||||
value => sprintf("%d", $timeoutcount),
|
|
||||||
warning => $self->{perfdata}->get_perfdata_for_output(label => 'warn_timeoutcount'),
|
|
||||||
critical => $self->{perfdata}->get_perfdata_for_output(label => 'crit_timeoutcount'),
|
|
||||||
);
|
|
||||||
$self->{output}->perfdata_add(label => "c[CommittedCount]", unit => '',
|
|
||||||
value => sprintf("%d", $committedcount),
|
|
||||||
);
|
|
||||||
$self->{output}->perfdata_add(label => "c[RolledbackCount]", unit => '',
|
|
||||||
value => sprintf("%d", $rolledbackcount),
|
|
||||||
);
|
|
||||||
$self->{output}->perfdata_add(label => "c[TransactionCount]", unit => '',
|
|
||||||
value => sprintf("%d", $transactioncount),
|
|
||||||
);
|
|
||||||
$self->{output}->perfdata_add(label => "c[TotalTransactionTime]", unit => 'ms',
|
|
||||||
value => sprintf("%d", $totaltransactiontime),
|
|
||||||
);
|
|
||||||
$self->{output}->perfdata_add(label => "MaxTransactionTime", unit => 'ms',
|
|
||||||
value => sprintf("%d", $maxtransactiontime),
|
|
||||||
);
|
|
||||||
$self->{output}->perfdata_add(label => "DefaultTimeout", unit => 's',
|
|
||||||
value => sprintf("%d", $defaulttimeout),
|
|
||||||
);
|
|
||||||
|
|
||||||
$self->{output}->display();
|
|
||||||
$self->{output}->exit();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
1;
|
1;
|
||||||
|
@ -156,13 +156,12 @@ Check EAS application EJB transaction status.
|
||||||
|
|
||||||
Set path to get status page. (Default: '/easportal/tools/nagios/checktransaction.jsp')
|
Set path to get status page. (Default: '/easportal/tools/nagios/checktransaction.jsp')
|
||||||
|
|
||||||
=item B<--warning>
|
=item B<--warning-*> B<--critical-*>
|
||||||
|
|
||||||
Warning Threshold for (activecount,timeoutcount). for example : --warning=100,1
|
Thresholds.
|
||||||
|
Can be: 'active', 'timedout', 'committed',
|
||||||
=item B<--critical>
|
'rolledback', 'created', 'time-total', 'time-max',
|
||||||
|
'timeout-default'.
|
||||||
Critical Threshold for (activecount,timeoutcount). for example : --critical=100,1
|
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue