
Puppet will now add a cron job and configure logrotate to backup etherpad-lite's MySQL DB daily and keep a months worth of backups. These are the defaults and are slightly configurable through the etherpad_lite::backup class. Also configure log rotation for etherpad-lite's error.log and access.log. Change-Id: I30e0a4c8ee852e6621ee74744968d85696658608
27 lines
710 B
Puppet
27 lines
710 B
Puppet
class etherpad_lite::backup (
|
|
$minute = '0',
|
|
$hour = '0',
|
|
$day = '*',
|
|
$dest = "${etherpad_lite::base_log_dir}/${etherpad_lite::ep_user}/db.sql.gz",
|
|
$rotation = 'daily',
|
|
$num_backups = '30'
|
|
) {
|
|
|
|
cron { eplitedbbackup:
|
|
ensure => present,
|
|
command => "/usr/bin/mysqldump --defaults-file=/etc/mysql/debian.cnf --opt etherpad-lite | gzip -9 > ${dest}",
|
|
minute => $minute,
|
|
hour => $hour,
|
|
weekday => $day,
|
|
require => Package['mysql-server']
|
|
}
|
|
|
|
include logrotate
|
|
logrotate::file { 'eplitedb':
|
|
log => $dest,
|
|
options => ['nocompress', 'missingok', "rotate ${num_backups}", $rotation],
|
|
require => Cron['eplitedbbackup']
|
|
}
|
|
|
|
}
|