module-puppetlabs-mysql/templates/mysqlbackup.sh.erb

79 lines
2.1 KiB
Text
Raw Normal View History

2015-03-30 21:56:31 +02:00
<%- if @kernel == 'Linux' -%>
#!/bin/bash
2015-03-30 21:56:31 +02:00
<%- else -%>
#!/bin/sh
<%- end -%>
#
# MySQL Backup Script
# Dumps mysql databases to a file for another backup tool to pick up.
#
# MySQL code:
# GRANT SELECT, RELOAD, LOCK TABLES ON *.* TO 'user'@'localhost'
# IDENTIFIED BY 'password';
# FLUSH PRIVILEGES;
#
##### START CONFIG ###################################################
USER=<%= @backupuser %>
PASS='<%= @backuppassword %>'
DIR=<%= @backupdir %>
ROTATE=<%= [ Integer(@backuprotate) - 1, 0 ].max %>
PREFIX=mysql_backup_
2014-01-29 13:22:12 +01:00
<% if @ignore_events %>
EVENTS="--ignore-table=mysql.event"
<% else %>
EVENTS="--events"
<% end %>
##### STOP CONFIG ####################################################
PATH=<%= @execpath %>
2014-01-29 13:22:12 +01:00
2015-03-30 21:56:31 +02:00
<%- if @kernel == 'Linux' -%>
set -o pipefail
2015-03-30 21:56:31 +02:00
<%- end -%>
cleanup()
{
find "${DIR}/" -maxdepth 1 -type f -name "${PREFIX}*.sql*" -mtime +${ROTATE} -print0 | xargs -0 -r rm -f
}
<% if @delete_before_dump -%>
cleanup
<% end -%>
<% if @backupdatabases.empty? -%>
<% if @file_per_database -%>
mysql -u${USER} -p${PASS} -s -r -N -e 'SHOW DATABASES' | while read dbname
do
mysqldump -u${USER} -p${PASS} --opt --flush-logs --single-transaction \
2014-01-29 13:22:12 +01:00
${EVENTS} \
${dbname} <% if @backupcompress %>| bzcat -zc <% end %>> ${DIR}/${PREFIX}${dbname}_`date +%Y%m%d-%H%M%S`.sql<% if @backupcompress %>.bz2<% end %>
done
<% else -%>
mysqldump -u${USER} -p${PASS} --opt --flush-logs --single-transaction \
2014-01-29 13:22:12 +01:00
${EVENTS} \
--all-databases <% if @backupcompress %>| bzcat -zc <% end %>> ${DIR}/${PREFIX}`date +%Y%m%d-%H%M%S`.sql<% if @backupcompress %>.bz2<% end %>
<% end -%>
<% else -%>
<% @backupdatabases.each do |db| -%>
mysqldump -u${USER} -p${PASS} --opt --flush-logs --single-transaction \
2014-01-29 13:22:12 +01:00
${EVENTS} \
<%= db %><% if @backupcompress %>| bzcat -zc <% end %>> ${DIR}/${PREFIX}<%= db %>_`date +%Y%m%d-%H%M%S`.sql<% if @backupcompress %>.bz2<% end %>
<% end -%>
<% end -%>
2013-07-10 05:12:38 +02:00
<% unless @delete_before_dump -%>
if [ $? -eq 0 ] ; then
cleanup
fi
<% end -%>
<% if @postscript -%>
<%- [@postscript].flatten.compact.each do |script|%>
<%= script %>
<%- end -%>
<% end -%>