diff options
author | Steve Kemp <steve@bytemark.co.uk> | 2016-09-21 12:27:06 +0100 |
---|---|---|
committer | Steve Kemp <steve@bytemark.co.uk> | 2016-09-21 12:27:06 +0100 |
commit | c68fe975ab4b47436bd90fa701b83a78793b0f32 (patch) | |
tree | 99ba226baa3d2d7cdac0470a9af93650e2449be0 /byteback-mysql/post-backup.d/00-mysql | |
parent | 2e96f802b1aa2cd374ef727c5573b30ab38001ce (diff) | |
parent | 10d3ddac7a625be28e9896f52bade5c99dc34462 (diff) |
Merge branch 'byteback-mysql' into 'master'
Byteback mysql
See merge request !3
Diffstat (limited to 'byteback-mysql/post-backup.d/00-mysql')
-rwxr-xr-x | byteback-mysql/post-backup.d/00-mysql | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/byteback-mysql/post-backup.d/00-mysql b/byteback-mysql/post-backup.d/00-mysql new file mode 100755 index 0000000..72369bf --- /dev/null +++ b/byteback-mysql/post-backup.d/00-mysql @@ -0,0 +1,27 @@ +#!/usr/bin/perl + +use warnings; +use strict; + +use lib '/etc/byteback/scripts.d'; +use Bytemyback::ini qw(readconf writeconf generateconf); + +use Sys::Hostname; + +# Shim script to determine which MySQL backup(s) to run if any + +my %config = Bytemyback::ini::readconf(); + +my $backup_method = $config{'backup_method'}; + +foreach my $method (keys %$backup_method) { + next unless $backup_method->{$method}; + print "Running /etc/byteback/scripts.d/Bytemyback/${method} post\n"; + `/etc/byteback/scripts.d/Bytemyback/${method} post` if (-x "/etc/byteback/scripts.d/Bytemyback/${method}"); + print "Finished /etc/byteback/scripts.d/Bytemyback/${method} post\n"; + + # Each script should have a heartbeat alert. They may also have specific failure alerts on both client and + # server side. + my $host = hostname; + system("mauvesend -i $method-hb-${host}-low -c now -r +26h -s 'MySQL backup method $method on ${host} has not run for over a day' --detail='Please try running manually to see what the problem was, and check the mailing list'"); +} |