forked from AmadeusITGroup/monitoring-plugins
-
Notifications
You must be signed in to change notification settings - Fork 0
/
check_bacula_age
executable file
·124 lines (105 loc) · 3.32 KB
/
check_bacula_age
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
#!/usr/bin/env perl
# check_bacula_age - Check the status of the last job for a bacula client
#
# Copyright (c) 2015 Amadeus Germany GmbH
#
# SPDX-License-Identifier: MIT
#
# Permission is hereby granted, free of charge, to any person obtaining a copy
# of this software and associated documentation files (the "Software"), to deal
# in the Software without restriction, including without limitation the rights
# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
# copies of the Software, and to permit persons to whom the Software is
# furnished to do so, subject to the following conditions:
#
# The above copyright notice and this permission notice shall be included in
# all copies or substantial portions of the Software.
#
# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
# SOFTWARE.
use strict;
use warnings;
use autodie;
use DBI;
use DateTime;
use DateTime::Format::Pg;
### START PLUGIN LOADER
sub load_module {
my $module;
eval "require $_" and $module = $_ and last for @_;
$module->import();
return $module;
}
my $plugin_module;
BEGIN {
$plugin_module = load_module('Monitoring::Plugin', 'Nagios::Plugin', 'Nagios::Monitoring::Plugin');
}
### END PLUGIN LOADER
my $np = $plugin_module->new(
usage => "Usage: %s [ -v|--verbose ] ",
version => '1.0.0',
plugin => 'check_bacula_age',
blurb => 'Check the status of the last job for a bacula client',
license => 'MIT',
);
$np->add_arg(
spec => 'dsn|d=s',
help => 'Database to use',
default => 'dbi:Pg:dbname=bacula',
);
$np->add_arg(
spec => 'user|u=s',
help => 'User to connect as',
default => 'bacula',
);
$np->add_arg(
spec => 'name|n=s',
help => 'Client to check',
required => 1,
);
$np->add_arg(
spec => 'critical|c=i',
help => 'Time in hours (critical)',
default => 50,
);
$np->add_arg(
spec => 'warning|w=i',
help => 'Time in hours (warning)',
default => 30,
);
$np->getopts;
my $dbh = DBI->connect($np->opts->dsn, $np->opts->user) or $np->nagios_die($DBI::errstr);
my $last_run_statement = <<'EOF';
SELECT * FROM job WHERE name = ? ORDER BY endtime DESC LIMIT 1;
EOF
my $results = $dbh->selectall_arrayref($last_run_statement, { Slice => {}}, $np->opts->name) or $np->nagios_die($dbh->errstr);
my $num_results = scalar(@$results);
if ($num_results != 1) {
$np->add_message(CRITICAL, "Found ${num_results} results instead of 1");
}
my $now = DateTime->now();
foreach my $r ( @$results ) {
my $last_run = DateTime::Format::Pg->parse_datetime($r->{endtime});
my $age = $now->subtract_datetime_absolute($last_run);
my $passed_hours = $age->in_units('seconds') / 3600;
$np->add_message(
$np->check_threshold(
check => $passed_hours,
warning => $np->opts->warning,
critical => $np->opts->critical,
),
sprintf("Last backup is %0.2f hours old", $passed_hours),
);
$np->add_perfdata(
label => 'age',
value => $age->in_units('seconds'),
uom => 's',
);
}
my ($code, $message) = $np->check_messages();
$np->nagios_exit($code, $message);