# # Copyright 2016 Centreon (http://www.centreon.com/) # # 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. # package apps::varnish::local::mode::workers; use base qw(centreon::plugins::mode); use centreon::plugins::misc; use centreon::plugins::statefile; use Digest::MD5 qw(md5_hex); my $maps_counters = { n_wrk => { thresholds => { warning_workers => { label => 'warning-workers', exit_value => 'warning' }, critical_workers => { label => 'critical-workers', exit_value => 'critical' }, }, output_msg => 'Backend conn. success: %.2f', factor => 1, unit => '', }, n_wrk_create => { thresholds => { warning_create => { label => 'warning-create', exit_value => 'warning' }, critical_create => { label => 'critical-create', exit_value => 'critical' }, }, output_msg => 'Backend conn. not attempted: %.2f', factor => 1, unit => '', }, n_wrk_failed => { thresholds => { warning_failed => { label => 'warning-failed', exit_value => 'warning' }, critical_failed => { label => 'critical-failed', exit_value => 'critical' }, }, output_msg => 'Backend conn. too many: %.2f', factor => 1, unit => '', }, n_wrk_max => { thresholds => { warning_max => { label => 'warning-max', exit_value => 'warning' }, critical_max => { label => 'critical-max', exit_value => 'critical' }, }, output_msg => 'Backend conn. failures: %.2f', factor => 1, unit => '', }, n_wrk_lqueue => { thresholds => { warning_lqueue => { label => 'warning-lqueue', exit_value => 'warning' }, critical_lqueue => { label => 'critical-lqueue', exit_value => 'critical' }, }, output_msg => 'Backend conn. reuses: %.2f', factor => 1, unit => '', }, n_wrk_queued => { thresholds => { warning_queued => { label => 'warning-queued', exit_value => 'warning' }, critical_queued => { label => 'critical-queued', exit_value => 'critical' }, }, output_msg => 'Backend conn. was closed: %.2f', factor => 1, unit => '', }, n_wrk_drop => { thresholds => { warning_drop => { label => 'warning-drop', exit_value => 'warning' }, critical_drop => { label => 'critical-drop', exit_value => 'critical' }, }, output_msg => 'Backend conn. recycles: %.2f', factor => 1, unit => '', }, }; sub new { my ($class, %options) = @_; my $self = $class->SUPER::new(package => __PACKAGE__, %options); bless $self, $class; $self->{version} = '1.0'; $options{options}->add_options(arguments => { "hostname:s" => { name => 'hostname' }, "remote" => { name => 'remote' }, "ssh-option:s@" => { name => 'ssh_option' }, "ssh-path:s" => { name => 'ssh_path' }, "ssh-command:s" => { name => 'ssh_command', default => 'ssh' }, "timeout:s" => { name => 'timeout', default => 30 }, "sudo" => { name => 'sudo' }, "command:s" => { name => 'command', default => 'varnishstat' }, "command-path:s" => { name => 'command_path', default => '/usr/bin' }, "command-options:s" => { name => 'command_options', default => ' -1 ' }, "command-options2:s" => { name => 'command_options2', default => ' 2>&1' }, }); foreach (keys %{$maps_counters}) { foreach my $name (keys %{$maps_counters->{$_}->{thresholds}}) { $options{options}->add_options(arguments => { $maps_counters->{$_}->{thresholds}->{$name}->{label} . ':s' => { name => $name }, }); }; }; $self->{instances_done} = {}; $self->{statefile_value} = centreon::plugins::statefile->new(%options); return $self; }; sub check_options { my ($self, %options) = @_; $self->SUPER::init(%options); foreach (keys %{$maps_counters}) { foreach my $name (keys %{$maps_counters->{$_}->{thresholds}}) { if (($self->{perfdata}->threshold_validate(label => $maps_counters->{$_}->{thresholds}->{$name}->{label}, value => $self->{option_results}->{$name})) == 0) { $self->{output}->add_option_msg(short_msg => "Wrong " . $maps_counters->{$_}->{thresholds}->{$name}->{label} . " threshold '" . $self->{option_results}->{$name} . "'."); $self->{output}->option_exit(); }; }; }; $self->{statefile_value}->check_options(%options); }; sub getdata { my ($self, %options) = @_; my $stdout = centreon::plugins::misc::execute(output => $self->{output}, options => $self->{option_results}, sudo => $self->{option_results}->{sudo}, command => $self->{option_results}->{command}, command_path => $self->{option_results}->{command_path}, command_options => $self->{option_results}->{command_options} . $self->{option_results}->{command_options2}); #print $stdout; foreach (split(/\n/, $stdout)) { #client_conn 7390867 1.00 Client connections # - Symbolic entry name # - Value # - Per-second average over process lifetime, or a period if the value can not be averaged # - Descriptive text if (/^(.\S*)\s*([0-9]*)\s*([0-9.]*)\s(.*)$/i) { #print "FOUND: " . $1 . "=" . $2 . "\n"; $self->{result}->{$1} = $2; }; }; }; sub run { my ($self, %options) = @_; $self->getdata(); $self->{statefile_value}->read(statefile => 'cache_apps_varnish' . '_' . $self->{mode} . '_' . (defined($self->{option_results}->{name}) ? md5_hex($self->{option_results}->{name}) : md5_hex('all'))); $self->{result}->{last_timestamp} = time(); my $old_timestamp = $self->{statefile_value}->get(name => 'last_timestamp'); # Calculate my $delta_time = $self->{result}->{last_timestamp} - $old_timestamp; $delta_time = 1 if ($delta_time == 0); # One seconds ;) foreach (keys %{$maps_counters}) { #print $_ . "\n"; $self->{old_cache}->{$_} = $self->{statefile_value}->get(name => '$_'); # Get Data from Cache $self->{old_cache}->{$_} = 0 if ( $self->{old_cache}->{$_} > $self->{result}->{$_} ); $self->{outputdata}->{$_} = ($self->{result}->{$_} - $self->{old_cache}->{$_}) / $delta_time; }; # Write Cache if not there $self->{statefile_value}->write(data => $self->{result}); if (!defined($old_timestamp)) { $self->{output}->output_add(severity => 'OK', short_msg => "Buffer creation..."); $self->{output}->display(); $self->{output}->exit(); } my @exits; foreach (keys %{$maps_counters}) { foreach my $name (keys %{$maps_counters->{$_}->{thresholds}}) { push @exits, $self->{perfdata}->threshold_check(value => $self->{outputdata}->{$_}, threshold => [ { label => $maps_counters->{$_}->{thresholds}->{$name}->{label}, 'exit_litteral' => $maps_counters->{$_}->{thresholds}->{$name}->{exit_value} }]); } } my $exit = $self->{output}->get_most_critical(status => [ @exits ]); my $extra_label = ''; $extra_label = '_' . $instance_output if ($num > 1); my $str_output = ""; my $str_append = ''; foreach (keys %{$maps_counters}) { $str_output .= $str_append . sprintf($maps_counters->{$_}->{output_msg}, $self->{outputdata}->{$_} * $maps_counters->{$_}->{factor}); $str_append = ', '; my ($warning, $critical); foreach my $name (keys %{$maps_counters->{$_}->{thresholds}}) { $warning = $self->{perfdata}->get_perfdata_for_output(label => $maps_counters->{$_}->{thresholds}->{$name}->{label}) if ($maps_counters->{$_}->{thresholds}->{$name}->{exit_value} eq 'warning'); $critical = $self->{perfdata}->get_perfdata_for_output(label => $maps_counters->{$_}->{thresholds}->{$name}->{label}) if ($maps_counters->{$_}->{thresholds}->{$name}->{exit_value} eq 'critical'); } $self->{output}->perfdata_add(label => $_ . $extra_label, unit => $maps_counters->{$_}->{unit}, value => sprintf("%.2f", $self->{outputdata}->{$_} * $maps_counters->{$_}->{factor}), warning => $warning, critical => $critical); } $self->{output}->output_add(severity => $exit, short_msg => $str_output); $self->{output}->display(); $self->{output}->exit(); }; 1; __END__ =head1 MODE Check Varnish Cache with varnishstat Command =over 8 =item B<--remote> If you dont run this script locally, if you wanna use it remote, you can run it remotely with 'ssh'. =item B<--hostname> Hostname to query (need --remote). =item B<--ssh-option> Specify multiple options like the user (example: --ssh-option='-l=centreon-engine' --ssh-option='-p=52'). =item B<--command> Varnishstat Binary Filename (Default: varnishstat) =item B<--command-path> Directory Path to Varnishstat Binary File (Default: /usr/bin) =item B<--command-options> Parameter for Binary File (Default: ' -1 ') =item B<--warning-*> Warning Threshold for: workers => N worker threads, create => N worker threads created, failed => N worker threads not created, max => N worker threads limited, lqueue => work request queue length, queued => N queued work requests, drop => N dropped work requests =item B<--critical-*> Critical Threshold for: workers => N worker threads, create => N worker threads created, failed => N worker threads not created, max => N worker threads limited, lqueue => work request queue length, queued => N queued work requests, drop => N dropped work requests =back =cut