2014-09-05 15:31:04 +02:00
|
|
|
#
|
2018-01-29 14:11:11 +01:00
|
|
|
# Copyright 2018 Centreon (http://www.centreon.com/)
|
2015-07-21 11:51:02 +02:00
|
|
|
#
|
|
|
|
# Centreon is a full-fledged industry-strength solution that meets
|
|
|
|
# the needs in IT infrastructure and application monitoring for
|
|
|
|
# service performance.
|
|
|
|
#
|
|
|
|
# Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
# you may not use this file except in compliance with the License.
|
|
|
|
# You may obtain a copy of the License at
|
|
|
|
#
|
|
|
|
# http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
#
|
|
|
|
# Unless required by applicable law or agreed to in writing, software
|
|
|
|
# distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
# See the License for the specific language governing permissions and
|
|
|
|
# limitations under the License.
|
|
|
|
#
|
2014-09-05 15:31:04 +02:00
|
|
|
|
2015-08-06 13:33:19 +02:00
|
|
|
package apps::php::apc::web::mode::filecache;
|
2014-09-05 15:31:04 +02:00
|
|
|
|
2017-08-07 13:26:24 +02:00
|
|
|
use base qw(centreon::plugins::templates::counter);
|
2014-09-05 15:31:04 +02:00
|
|
|
|
|
|
|
use strict;
|
|
|
|
use warnings;
|
2015-07-28 18:17:04 +02:00
|
|
|
use centreon::plugins::http;
|
2017-08-07 13:26:24 +02:00
|
|
|
use Digest::MD5 qw(md5_hex);
|
2014-09-05 15:31:04 +02:00
|
|
|
|
2017-08-07 13:26:24 +02:00
|
|
|
sub set_counters {
|
|
|
|
my ($self, %options) = @_;
|
|
|
|
|
|
|
|
$self->{maps_counters_type} = [
|
|
|
|
{ name => 'fcache', type => 0, cb_prefix_output => 'prefix_output' }
|
|
|
|
];
|
|
|
|
|
|
|
|
$self->{maps_counters}->{fcache} = [
|
|
|
|
{ label => 'request-rate', set => {
|
|
|
|
key_values => [ { name => 'rr' } ],
|
|
|
|
output_template => 'Request Rate (global): %.2f',
|
|
|
|
perfdatas => [
|
|
|
|
{ value => 'rr_absolute', label => 'request_rate',template => '%.2f',
|
|
|
|
unit => 'r/s', min => 0 },
|
|
|
|
],
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{ label => 'request-rate-now', set => {
|
|
|
|
key_values => [ { name => 'hits', diff => 1 }, { name => 'misses', diff => 1 } ],
|
|
|
|
closure_custom_calc => $self->can('custom_rr_calc'), per_second => 1,
|
|
|
|
output_template => 'Request Rate : %.2f', output_error_template => 'Request Rate : %s',
|
|
|
|
output_use => 'rr_now', threshold_use => 'rr_now',
|
|
|
|
perfdatas => [
|
|
|
|
{ value => 'rr_now', label => 'request_rate_now', template => '%.2f',
|
|
|
|
unit => 'r/s', min => 0 },
|
|
|
|
],
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{ label => 'hit-rate', set => {
|
|
|
|
key_values => [ { name => 'hr' } ],
|
|
|
|
output_template => 'Hit Rate (global): %.2f',
|
|
|
|
perfdatas => [
|
|
|
|
{ value => 'hr_absolute', label => 'hit_rate',template => '%.2f',
|
|
|
|
unit => 'r/s', min => 0 },
|
|
|
|
],
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{ label => 'hit-rate-now', set => {
|
|
|
|
key_values => [ { name => 'hits', diff => 1 } ],
|
|
|
|
closure_custom_calc => $self->can('custom_hr_calc'), per_second => 1,
|
|
|
|
output_template => 'Hit Rate : %.2f', output_error_template => 'Hit Rate : %s',
|
|
|
|
output_use => 'hr_now', threshold_use => 'hr_now',
|
|
|
|
perfdatas => [
|
|
|
|
{ value => 'hr_now', label => 'hit_rate_now', template => '%.2f',
|
|
|
|
unit => 'r/s', min => 0 },
|
|
|
|
],
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{ label => 'miss-rate', set => {
|
|
|
|
key_values => [ { name => 'mr' } ],
|
|
|
|
output_template => 'Miss Rate (global): %.2f',
|
|
|
|
perfdatas => [
|
|
|
|
{ value => 'mr_absolute', label => 'miss_rate',template => '%.2f',
|
|
|
|
unit => 'r/s', min => 0 },
|
|
|
|
],
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{ label => 'miss-rate-now', set => {
|
|
|
|
key_values => [ { name => 'misses', diff => 1 } ],
|
|
|
|
closure_custom_calc => $self->can('custom_mr_calc'), per_second => 1,
|
|
|
|
output_template => 'Miss Rate : %.2f', output_error_template => 'Miss Rate : %s',
|
|
|
|
output_use => 'mr_now', threshold_use => 'mr_now',
|
|
|
|
perfdatas => [
|
|
|
|
{ value => 'mr_now', label => 'miss_rate_now', template => '%.2f',
|
|
|
|
unit => 'r/s', min => 0 },
|
|
|
|
],
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{ label => 'hit-percent', set => {
|
|
|
|
key_values => [ { name => 'hits' }, { name => 'misses' } ],
|
|
|
|
closure_custom_calc => $self->can('custom_hit_percent_calc'),
|
|
|
|
output_template => 'Hit Ratio (global) : %.2f %%', output_error_template => 'Hit Ratio (global): %s',
|
|
|
|
output_use => 'hit_ratio', threshold_use => 'hit_ratio',
|
|
|
|
perfdatas => [
|
|
|
|
{ value => 'hit_ratio', label => 'hit_ratio', template => '%.2f',
|
|
|
|
unit => '%', min => 0, max => 100 },
|
|
|
|
],
|
|
|
|
}
|
|
|
|
},
|
|
|
|
{ label => 'hit-percent-now', set => {
|
|
|
|
key_values => [ { name => 'hits', diff => 1 }, { name => 'misses', diff => 1 } ],
|
|
|
|
closure_custom_calc => $self->can('custom_hit_percent_now_calc'),
|
|
|
|
output_template => 'Hit Ratio : %.2f %%', output_error_template => 'Hit Ratio : %s',
|
|
|
|
output_use => 'hit_ratio_now', threshold_use => 'hit_ratio_now',
|
|
|
|
perfdatas => [
|
|
|
|
{ value => 'hit_ratio_now', label => 'hit_ratio_now', template => '%.2f',
|
|
|
|
unit => '%', min => 0, max => 100 },
|
|
|
|
],
|
|
|
|
}
|
|
|
|
},
|
|
|
|
];
|
|
|
|
}
|
2014-09-05 15:31:04 +02:00
|
|
|
|
|
|
|
sub custom_rr_calc {
|
|
|
|
my ($self, %options) = @_;
|
|
|
|
my $total = ($options{new_datas}->{$self->{instance} . '_hits'} - $options{old_datas}->{$self->{instance} . '_hits'})
|
|
|
|
+ ($options{new_datas}->{$self->{instance} . '_misses'} - $options{old_datas}->{$self->{instance} . '_misses'});
|
|
|
|
|
|
|
|
if ($total == 0) {
|
|
|
|
$self->{error_msg} = "skipped";
|
|
|
|
return -2;
|
|
|
|
}
|
|
|
|
|
|
|
|
$self->{result_values}->{rr_now} = $total / $options{delta_time};
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
sub custom_hr_calc {
|
|
|
|
my ($self, %options) = @_;
|
|
|
|
my $total = ($options{new_datas}->{$self->{instance} . '_hits'} - $options{old_datas}->{$self->{instance} . '_hits'});
|
|
|
|
|
|
|
|
if ($total == 0) {
|
|
|
|
$self->{error_msg} = "skipped";
|
|
|
|
return -2;
|
|
|
|
}
|
|
|
|
|
|
|
|
$self->{result_values}->{hr_now} = $total / $options{delta_time};
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
sub custom_mr_calc {
|
|
|
|
my ($self, %options) = @_;
|
|
|
|
my $total = ($options{new_datas}->{$self->{instance} . '_misses'} - $options{old_datas}->{$self->{instance} . '_misses'});
|
|
|
|
|
|
|
|
if ($total == 0) {
|
|
|
|
$self->{error_msg} = "skipped";
|
|
|
|
return -2;
|
|
|
|
}
|
|
|
|
|
|
|
|
$self->{result_values}->{mr_now} = $total / $options{delta_time};
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
sub custom_hit_percent_now_calc {
|
|
|
|
my ($self, %options) = @_;
|
|
|
|
my $hits = ($options{new_datas}->{$self->{instance} . '_hits'} - $options{old_datas}->{$self->{instance} . '_hits'});
|
|
|
|
my $total = $hits + ($options{new_datas}->{$self->{instance} . '_misses'} - $options{old_datas}->{$self->{instance} . '_misses'});
|
|
|
|
|
|
|
|
if ($total == 0) {
|
|
|
|
$self->{error_msg} = "skipped";
|
|
|
|
return -2;
|
|
|
|
}
|
|
|
|
|
|
|
|
$self->{result_values}->{hit_ratio_now} = $hits * 100 / $total;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
sub custom_hit_percent_calc {
|
|
|
|
my ($self, %options) = @_;
|
|
|
|
my $hits = ($options{new_datas}->{$self->{instance} . '_hits'});
|
|
|
|
my $total = $hits + ($options{new_datas}->{$self->{instance} . '_misses'});
|
|
|
|
|
|
|
|
if ($total == 0) {
|
|
|
|
$self->{error_msg} = "skipped";
|
|
|
|
return -2;
|
|
|
|
}
|
|
|
|
|
|
|
|
$self->{result_values}->{hit_ratio} = $hits * 100 / $total;
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2017-08-07 13:26:24 +02:00
|
|
|
sub prefix_output {
|
|
|
|
my ($self, %options) = @_;
|
|
|
|
|
|
|
|
return "Apc File Cache Information ";
|
|
|
|
}
|
|
|
|
|
2014-09-05 15:31:04 +02:00
|
|
|
sub new {
|
|
|
|
my ($class, %options) = @_;
|
2017-08-07 13:26:24 +02:00
|
|
|
my $self = $class->SUPER::new(package => __PACKAGE__, %options, statefile => 1);
|
2014-09-05 15:31:04 +02:00
|
|
|
bless $self, $class;
|
|
|
|
|
|
|
|
$self->{version} = '1.0';
|
|
|
|
$options{options}->add_options(arguments =>
|
|
|
|
{
|
|
|
|
"hostname:s" => { name => 'hostname' },
|
|
|
|
"port:s" => { name => 'port', },
|
2015-07-28 18:17:04 +02:00
|
|
|
"proto:s" => { name => 'proto' },
|
2014-09-05 15:31:04 +02:00
|
|
|
"urlpath:s" => { name => 'url_path', default => "/apc.php" },
|
|
|
|
"credentials" => { name => 'credentials' },
|
2018-05-02 09:31:06 +02:00
|
|
|
"basic" => { name => 'basic' },
|
2014-09-05 15:31:04 +02:00
|
|
|
"username:s" => { name => 'username' },
|
|
|
|
"password:s" => { name => 'password' },
|
|
|
|
"proxyurl:s" => { name => 'proxyurl' },
|
|
|
|
"timeout:s" => { name => 'timeout', default => 30 },
|
2018-04-23 13:54:07 +02:00
|
|
|
"ssl-opt:s@" => { name => 'ssl_opt' },
|
2014-09-05 15:31:04 +02:00
|
|
|
});
|
|
|
|
|
2015-07-28 18:17:04 +02:00
|
|
|
$self->{http} = centreon::plugins::http->new(output => $self->{output});
|
2014-09-05 15:31:04 +02:00
|
|
|
|
|
|
|
return $self;
|
|
|
|
}
|
|
|
|
|
|
|
|
sub check_options {
|
|
|
|
my ($self, %options) = @_;
|
2017-08-07 13:26:24 +02:00
|
|
|
$self->SUPER::check_options(%options);
|
2014-09-05 15:31:04 +02:00
|
|
|
|
2015-07-28 18:17:04 +02:00
|
|
|
$self->{http}->set_options(%{$self->{option_results}});
|
2014-09-05 15:31:04 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
sub manage_selection {
|
|
|
|
my ($self, %options) = @_;
|
|
|
|
|
2017-08-07 17:08:38 +02:00
|
|
|
my $webcontent = $self->{http}->request();
|
2017-08-07 13:26:24 +02:00
|
|
|
|
2014-09-05 15:31:04 +02:00
|
|
|
$self->{fcache} = {};
|
2017-08-07 13:26:24 +02:00
|
|
|
$self->{fcache}->{hits} = $webcontent =~ /File Cache Information.*?Hits.*?(\d+)/msi ? $1 : undef;
|
|
|
|
$self->{fcache}->{misses} = $webcontent =~ /File Cache Information.*?Misses.*?(\d+)/msi ? $1 : undef;
|
|
|
|
$self->{fcache}->{rr} = $webcontent =~ /File Cache Information.*?Request Rate.*?([0-9\.]+)/msi ? $1 : undef;
|
|
|
|
$self->{fcache}->{hr} = $webcontent =~ /File Cache Information.*?Hit Rate.*?([0-9\.]+)/msi ? $1 : undef;
|
|
|
|
$self->{fcache}->{mr} = $webcontent =~ /File Cache Information.*?Miss Rate.*?([0-9\.]+)/msi ? $1 : undef;
|
|
|
|
$self->{fcache}->{ir} = $webcontent =~ /File Cache Information.*?Insert Rate.*?([0-9\.]+)/msi ? $1 : undef;
|
|
|
|
|
|
|
|
$self->{cache_name} = "apc_" . $self->{mode} . '_' . $self->{option_results}->{hostname} . '_' . $self->{http}->get_port() . '_' .
|
|
|
|
(defined($self->{option_results}->{filter_counters}) ? md5_hex($self->{option_results}->{filter_counters}) : md5_hex('all'));
|
2014-09-05 15:31:04 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
1;
|
|
|
|
|
|
|
|
__END__
|
|
|
|
|
|
|
|
=head1 MODE
|
|
|
|
|
|
|
|
Check file cache informations.
|
|
|
|
|
|
|
|
=over 8
|
|
|
|
|
|
|
|
=item B<--hostname>
|
|
|
|
|
|
|
|
IP Addr/FQDN of the webserver host
|
|
|
|
|
|
|
|
=item B<--port>
|
|
|
|
|
|
|
|
Port used by web server
|
|
|
|
|
|
|
|
=item B<--proxyurl>
|
|
|
|
|
|
|
|
Proxy URL if any
|
|
|
|
|
|
|
|
=item B<--proto>
|
|
|
|
|
|
|
|
Specify https if needed
|
|
|
|
|
|
|
|
=item B<--urlpath>
|
|
|
|
|
|
|
|
Set path to get server-status page in auto mode (Default: '/apc.php')
|
|
|
|
|
|
|
|
=item B<--credentials>
|
|
|
|
|
2018-05-02 09:31:06 +02:00
|
|
|
Specify this option if you access server-status page with authentication
|
2014-09-05 15:31:04 +02:00
|
|
|
|
|
|
|
=item B<--username>
|
|
|
|
|
2018-05-02 09:31:06 +02:00
|
|
|
Specify username for authentication (Mandatory if --credentials is specified)
|
2014-09-05 15:31:04 +02:00
|
|
|
|
|
|
|
=item B<--password>
|
|
|
|
|
2018-05-02 09:31:06 +02:00
|
|
|
Specify password for authentication (Mandatory if --credentials is specified)
|
|
|
|
|
|
|
|
=item B<--basic>
|
|
|
|
|
|
|
|
Specify this option if you access server-status page over basic authentication and don't want a '401 UNAUTHORIZED' error to be logged on your webserver.
|
|
|
|
|
|
|
|
Specify this option if you access server-status page over hidden basic authentication or you'll get a '404 NOT FOUND' error.
|
|
|
|
|
|
|
|
(Use with --credentials)
|
2014-09-05 15:31:04 +02:00
|
|
|
|
|
|
|
=item B<--timeout>
|
|
|
|
|
|
|
|
Threshold for HTTP timeout (Default: 30)
|
|
|
|
|
2018-04-23 13:54:07 +02:00
|
|
|
=item B<--ssl-opt>
|
|
|
|
|
|
|
|
Set SSL Options (--ssl-opt="SSL_version => TLSv1" --ssl-opt="SSL_verify_mode => SSL_VERIFY_NONE").
|
|
|
|
|
2014-09-05 15:31:04 +02:00
|
|
|
=item B<--warning-*>
|
|
|
|
|
|
|
|
Threshold warning.
|
|
|
|
Can be: 'request-rate', 'request-rate-now',
|
2017-08-07 16:41:23 +02:00
|
|
|
'hit-rate', 'hit-rate-now', 'miss-rate', 'miss-rate-now',
|
2014-09-05 15:31:04 +02:00
|
|
|
'hit-percent', 'hit-percent-now'.
|
|
|
|
'*-now' are rate between two calls.
|
|
|
|
|
|
|
|
=item B<--critical-*>
|
|
|
|
|
|
|
|
Threshold critical.
|
|
|
|
Can be: 'request-rate', 'request-rate-now',
|
2017-08-07 16:41:23 +02:00
|
|
|
'hit-rate', 'hit-rate-now', 'miss-rate', 'miss-rate-now',
|
2014-09-05 15:31:04 +02:00
|
|
|
'hit-percent', 'hit-percent-now'.
|
|
|
|
'*-now' are rate between two calls.
|
|
|
|
|
|
|
|
=back
|
|
|
|
|
|
|
|
=cut
|