Fix #5529
Better management of corrupted files Add an option to use module 'Storable' (instead 'Data::Dumper') Better error for some extra modules (like xml, json, memcached,...)
This commit is contained in:
parent
aecf305429
commit
bf1f061953
|
@ -129,6 +129,8 @@ sub run {
|
||||||
$self->{output}->option_exit();
|
$self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
$rPerSec = '0' . $rPerSec if ($rPerSec =~ /^\./);
|
$rPerSec = '0' . $rPerSec if ($rPerSec =~ /^\./);
|
||||||
|
$avg_bPerSec = '0' . $avg_bPerSec if ($avg_bPerSec =~ /^\./);
|
||||||
|
$bPerReq = '0' . $bPerReq if ($bPerReq =~ /^\./);
|
||||||
|
|
||||||
$self->{statefile_value}->read(statefile => 'apache_' . $self->{option_results}->{hostname} . '_' . centreon::plugins::httplib::get_port($self) . '_' . $self->{mode});
|
$self->{statefile_value}->read(statefile => 'apache_' . $self->{option_results}->{hostname} . '_' . centreon::plugins::httplib::get_port($self) . '_' . $self->{mode});
|
||||||
my $old_timestamp = $self->{statefile_value}->get(name => 'last_timestamp');
|
my $old_timestamp = $self->{statefile_value}->get(name => 'last_timestamp');
|
||||||
|
|
|
@ -564,7 +564,8 @@ sub is_litteral_status {
|
||||||
sub create_json_document {
|
sub create_json_document {
|
||||||
my ($self) = @_;
|
my ($self) = @_;
|
||||||
|
|
||||||
require JSON;
|
centreon::plugins::misc::mymodule_load(output => $self->{output}, module => 'JSON',
|
||||||
|
error_msg => "Cannot load module 'JSON'.");
|
||||||
$self->{is_output_json} = 1;
|
$self->{is_output_json} = 1;
|
||||||
$self->{json_output} = JSON->new->utf8();
|
$self->{json_output} = JSON->new->utf8();
|
||||||
}
|
}
|
||||||
|
@ -572,7 +573,8 @@ sub create_json_document {
|
||||||
sub create_xml_document {
|
sub create_xml_document {
|
||||||
my ($self) = @_;
|
my ($self) = @_;
|
||||||
|
|
||||||
require XML::LibXML;
|
centreon::plugins::misc::mymodule_load(output => $self->{output}, module => 'XML::LibXML',
|
||||||
|
error_msg => "Cannot load module 'XML::LibXML'.");
|
||||||
$self->{is_output_xml} = 1;
|
$self->{is_output_xml} = 1;
|
||||||
$self->{xml_output} = XML::LibXML::Document->new('1.0', 'utf-8');
|
$self->{xml_output} = XML::LibXML::Document->new('1.0', 'utf-8');
|
||||||
}
|
}
|
||||||
|
|
|
@ -39,6 +39,7 @@ use strict;
|
||||||
use warnings;
|
use warnings;
|
||||||
use Data::Dumper;
|
use Data::Dumper;
|
||||||
use vars qw($datas);
|
use vars qw($datas);
|
||||||
|
use centreon::plugins::misc;
|
||||||
|
|
||||||
my $default_dir = '/var/lib/centreon/centplugins';
|
my $default_dir = '/var/lib/centreon/centplugins';
|
||||||
|
|
||||||
|
@ -53,12 +54,15 @@ sub new {
|
||||||
"memcached:s" => { name => 'memcached' },
|
"memcached:s" => { name => 'memcached' },
|
||||||
"statefile-dir:s" => { name => 'statefile_dir', default => $default_dir },
|
"statefile-dir:s" => { name => 'statefile_dir', default => $default_dir },
|
||||||
"statefile-concat-cwd" => { name => 'statefile_concat_cwd' },
|
"statefile-concat-cwd" => { name => 'statefile_concat_cwd' },
|
||||||
|
"statefile-storable" => { name => 'statefile_storable' },
|
||||||
});
|
});
|
||||||
$options{options}->add_help(package => __PACKAGE__, sections => 'RETENTION OPTIONS', once => 1);
|
$options{options}->add_help(package => __PACKAGE__, sections => 'RETENTION OPTIONS', once => 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
$self->{output} = $options{output};
|
$self->{output} = $options{output};
|
||||||
$self->{datas} = {};
|
$self->{datas} = {};
|
||||||
|
$self->{storable} = 0;
|
||||||
|
$self->{memcached_ok} = 0;
|
||||||
$self->{memcached} = undef;
|
$self->{memcached} = undef;
|
||||||
|
|
||||||
$self->{statefile_dir} = undef;
|
$self->{statefile_dir} = undef;
|
||||||
|
@ -70,15 +74,22 @@ sub check_options {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
if (defined($options{option_results}) && defined($options{option_results}->{memcached})) {
|
if (defined($options{option_results}) && defined($options{option_results}->{memcached})) {
|
||||||
require Memcached::libmemcached;
|
centreon::plugins::misc::mymodule_load(output => $self->{output}, module => 'Memcached::libmemcached',
|
||||||
|
error_msg => "Cannot load module 'Memcached::libmemcached'.");
|
||||||
$self->{memcached} = Memcached::libmemcached->new();
|
$self->{memcached} = Memcached::libmemcached->new();
|
||||||
Memcached::libmemcached::memcached_server_add($self->{memcached}, $options{option_results}->{memcached});
|
Memcached::libmemcached::memcached_server_add($self->{memcached}, $options{option_results}->{memcached});
|
||||||
}
|
}
|
||||||
$self->{statefile_dir} = $options{option_results}->{statefile_dir};
|
$self->{statefile_dir} = $options{option_results}->{statefile_dir};
|
||||||
if ($self->{statefile_dir} ne $default_dir && defined($options{option_results}->{statefile_concat_cwd})) {
|
if ($self->{statefile_dir} ne $default_dir && defined($options{option_results}->{statefile_concat_cwd})) {
|
||||||
require Cwd;
|
centreon::plugins::misc::mymodule_load(output => $self->{output}, module => 'Cwd',
|
||||||
|
error_msg => "Cannot load module 'Cwd'.");
|
||||||
$self->{statefile_dir} = Cwd::cwd() . '/' . $self->{statefile_dir};
|
$self->{statefile_dir} = Cwd::cwd() . '/' . $self->{statefile_dir};
|
||||||
}
|
}
|
||||||
|
if (defined($options{option_results}->{statefile_storable})) {
|
||||||
|
centreon::plugins::misc::mymodule_load(output => $self->{output}, module => 'Storable',
|
||||||
|
error_msg => "Cannot load module 'Storable'.");
|
||||||
|
$self->{storable} = 1;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
sub read {
|
sub read {
|
||||||
|
@ -90,6 +101,7 @@ sub read {
|
||||||
# if "SUCCESS" or "NOT FOUND" is ok. Other with use the file
|
# if "SUCCESS" or "NOT FOUND" is ok. Other with use the file
|
||||||
my $val = Memcached::libmemcached::memcached_get($self->{memcached}, $self->{statefile_dir} . "/" . $self->{statefile});
|
my $val = Memcached::libmemcached::memcached_get($self->{memcached}, $self->{statefile_dir} . "/" . $self->{statefile});
|
||||||
if (defined($self->{memcached}->errstr) && $self->{memcached}->errstr =~ /^SUCCESS|NOT FOUND$/i) {
|
if (defined($self->{memcached}->errstr) && $self->{memcached}->errstr =~ /^SUCCESS|NOT FOUND$/i) {
|
||||||
|
$self->{memcached_ok} = 1;
|
||||||
if (defined($val)) {
|
if (defined($val)) {
|
||||||
eval( $val );
|
eval( $val );
|
||||||
$self->{datas} = $datas;
|
$self->{datas} = $datas;
|
||||||
|
@ -98,7 +110,6 @@ sub read {
|
||||||
}
|
}
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
$self->{memcached_ok} = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (! -e $self->{statefile_dir} . "/" . $self->{statefile}) {
|
if (! -e $self->{statefile_dir} . "/" . $self->{statefile}) {
|
||||||
|
@ -115,22 +126,36 @@ sub read {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
unless (my $return = do $self->{statefile_dir} . "/" . $self->{statefile}) {
|
if ($self->{storable} == 1) {
|
||||||
|
open FILE, $self->{statefile_dir} . "/" . $self->{statefile};
|
||||||
|
eval {
|
||||||
|
$self->{datas} = Storable::fd_retrieve(*FILE);
|
||||||
|
};
|
||||||
|
# File is corrupted surely. We'll reset it
|
||||||
if ($@) {
|
if ($@) {
|
||||||
$self->{output}->add_option_msg(short_msg => "Couldn't parse '" . $self->{statefile_dir} . "/" . $self->{statefile} . "': $@");
|
close FILE;
|
||||||
$self->{output}->option_exit();
|
return 0;
|
||||||
}
|
|
||||||
unless (defined($return)) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Couldn't do '" . $self->{statefile_dir} . "/" . $self->{statefile} . "': $!");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
|
||||||
unless ($return) {
|
|
||||||
$self->{output}->add_option_msg(short_msg => "Couldn't run '" . $self->{statefile_dir} . "/" . $self->{statefile} . "': $!");
|
|
||||||
$self->{output}->option_exit();
|
|
||||||
}
|
}
|
||||||
|
close FILE;
|
||||||
|
} else {
|
||||||
|
unless (my $return = do $self->{statefile_dir} . "/" . $self->{statefile}) {
|
||||||
|
# File is corrupted surely. We'll reset it
|
||||||
|
return 0;
|
||||||
|
#if ($@) {
|
||||||
|
# $self->{output}->add_option_msg(short_msg => "Couldn't parse '" . $self->{statefile_dir} . "/" . $self->{statefile} . "': $@");
|
||||||
|
# $self->{output}->option_exit();
|
||||||
|
#}
|
||||||
|
#unless (defined($return)) {
|
||||||
|
# $self->{output}->add_option_msg(short_msg => "Couldn't do '" . $self->{statefile_dir} . "/" . $self->{statefile} . "': $!");
|
||||||
|
# $self->{output}->option_exit();
|
||||||
|
#}
|
||||||
|
#unless ($return) {
|
||||||
|
# $self->{output}->add_option_msg(short_msg => "Couldn't run '" . $self->{statefile_dir} . "/" . $self->{statefile} . "': $!");
|
||||||
|
# $self->{output}->option_exit();
|
||||||
}
|
}
|
||||||
$self->{datas} = $datas;
|
$self->{datas} = $datas;
|
||||||
$datas = {};
|
$datas = {};
|
||||||
|
}
|
||||||
|
|
||||||
return 1;
|
return 1;
|
||||||
}
|
}
|
||||||
|
@ -153,7 +178,7 @@ sub get {
|
||||||
sub write {
|
sub write {
|
||||||
my ($self, %options) = @_;
|
my ($self, %options) = @_;
|
||||||
|
|
||||||
if (defined($self->{memcached})) {
|
if ($self->{memcached_ok} == 1) {
|
||||||
Memcached::libmemcached::memcached_set($self->{memcached}, $self->{statefile_dir} . "/" . $self->{statefile},
|
Memcached::libmemcached::memcached_set($self->{memcached}, $self->{statefile_dir} . "/" . $self->{statefile},
|
||||||
Data::Dumper->Dump([$options{data}], ["datas"]));
|
Data::Dumper->Dump([$options{data}], ["datas"]));
|
||||||
if (defined($self->{memcached}->errstr) && $self->{memcached}->errstr =~ /^SUCCESS$/i) {
|
if (defined($self->{memcached}->errstr) && $self->{memcached}->errstr =~ /^SUCCESS$/i) {
|
||||||
|
@ -161,7 +186,11 @@ sub write {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
open FILE, ">", $self->{statefile_dir} . "/" . $self->{statefile};
|
open FILE, ">", $self->{statefile_dir} . "/" . $self->{statefile};
|
||||||
|
if ($self->{storable} == 1) {
|
||||||
|
Storable::store_fd($options{data}, *FILE);
|
||||||
|
} else {
|
||||||
print FILE Data::Dumper->Dump([$options{data}], ["datas"]);
|
print FILE Data::Dumper->Dump([$options{data}], ["datas"]);
|
||||||
|
}
|
||||||
close FILE;
|
close FILE;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -194,6 +223,10 @@ Directory for statefile (Default: '/var/lib/centreon/centplugins').
|
||||||
Concat current working directory with option '--statefile-dir'.
|
Concat current working directory with option '--statefile-dir'.
|
||||||
Useful on Windows when plugin is compiled.
|
Useful on Windows when plugin is compiled.
|
||||||
|
|
||||||
|
=item B<--statefile-storable>
|
||||||
|
|
||||||
|
Use Perl Module 'Storable' (instead Data::Dumper) to store datas.
|
||||||
|
|
||||||
=back
|
=back
|
||||||
|
|
||||||
=head1 DESCRIPTION
|
=head1 DESCRIPTION
|
||||||
|
|
Loading…
Reference in New Issue