blob: f8e1ccbcd49fb15b0fcfc26ff3c7da63116e9af5 (
plain)
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
|
#!/bin/bash
basedir="/var/backup"
prefix="daily"
count="25"
list="dirs.list"
(
mountpoint -q $basedir && umount $basedir
fsck -y /dev/data/backup
mount ${basedir}
echo "Start @ `date`" > ${basedir}/time
last=${basedir}/${prefix}.${count}
if [ -d ${last} ]; then
rm -r ${last}
fi
for n in `seq ${count} -1 1`; do
((m=$n - 1))
src=${basedir}/${prefix}.$m
dest=${basedir}/${prefix}.$n
if [ -d ${src} ]; then
if [ ${m} -eq 0 ]; then
cp -rlP ${src} ${dest}
else
mv ${src} ${dest}
fi
else
mkdir ${dest}
fi
done
for src in `cat ${basedir}/${list}`; do
dest=${basedir}/${prefix}.0/${src}
if [ ! -d ${dest} ]; then
mkdir -p ${dest}
fi
rsync -ax --delete ${src} ${dest}
done
hardlink -t ${basedir}/${prefix}.?
echo "Begin MySQL @ `date`" >> ${basedir}/time
rm -f ${basedir}/${prefix}.0/mysql.sql.xz
mysqldump --defaults-extra-file=/root/.my.cnf --extended-insert=off -xA | xz > ${basedir}/${prefix}.0/mysql.sql.xz
echo "Begin LDAP @ `date`" >> ${basedir}/time
rm -f ${basedir}/${prefix}.0/ldap.ldif.xz
ldapsearch | xz > ${basedir}/${prefix}.0/ldap.ldif.xz
echo "Begin PostgreSQL @ `date`" >> ${basedir}/time
rm -f ${basedir}/${prefix}.0/postgresql-gentoobrowse.sql.xz
pg_dump -Upostgres gentoobrowse | xz > ${basedir}/${prefix}.0/postgresql-gentoobrowse.sql.xz
rm -f ${basedir}/${prefix}.0/postgresql-p2pvr.sql.xz
pg_dump -Upostgres p2pvr | xz > ${basedir}/${prefix}.0/postgresql-p2pvr.sql.xz
rm -f ${basedir}/${prefix}.0/postgresql-bugzilla.sql.xz
pg_dump -Upostgres bugzilla | xz > ${basedir}/${prefix}.0/postgresql-bugzilla.sql.xz
echo "End @ `date`" >> ${basedir}/time
umount ${basedir}
) | tee /var/log/backup.log
|