-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathBackup_targz.sh
73 lines (64 loc) · 2.89 KB
/
Backup_targz.sh
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
#!/usr/bin/env bash
######################### Parameters ##########################################
backup_arr=("/boot" "/etc" "/home" "/opt" "/root" "/srv" "/usr" "/var")
exclude_arr=("")
targz_repo="/data/system_maintenance/system_backup/"
bkNumber=5
threads=16
broadcast="TRUE"
###############################################################################
pigz --version &>/dev/null
[ $? -eq 127 ] && {
echo -e "Cannot find the command pigz.\n"
exit 1
}
if [[ ! -d $targz_repo ]]; then
echo -e "ERROR! Cannot find the repository directory: $targz_repo"
exit 1
fi
####### Start preocessing #######
tag="bk_$(date +"%Y-%m-%d-%H.%M.%S")"
bk_dir=$targz_repo/$tag
logfile=$bk_dir/Backup_individual.log
error_pattern="(error)|(fatal)|(corrupt)|(interrupt)|(EOFException)|(no such file or directory)"
bk_dir_existed=($(find $targz_repo -mindepth 1 -maxdepth 1 -type d -name "bk_*"))
if ((${#bk_dir_existed[*]} >= 1)); then
if (($(ls -d $targz_repo/bk_*/ | wc -l) >= $bkNumber)); then
rm_num=$(($(ls -d $targz_repo/bk_*/ | wc -l) - $bkNumber + 1))
ls -dt $targz_repo/bk_*/ | tail -$rm_num | xargs -i rm -rf {}
fi
fi
mkdir -p $bk_dir
SECONDS=0
echo -e "****************** Start Backup ******************" &>>$logfile
echo -e ">>> Backup start at $(date +'%Y-%m-%d %H:%M:%S')" &>>$logfile
echo -e ">>> Backup targets: ${backup_arr[*]}" &>>$logfile
echo -e ">>> Backup targets excluding: ${exclude_arr[*]}\n" &>>$logfile
exclude_par=$(printf -- " --exclude '%s'" "${exclude_arr[@]}")
for target in "${backup_arr[@]}"; do
echo -e "*** Make a backup for the target: $target" &>>$logfile
bkfile=${target#/}
bkfile=${bkfile//\//.}.tar.gz
tar $exclude_par -cpPf - $target 2>>$logfile | pigz -9 -p $threads >$bk_dir/$bkfile 2>>$logfile
if [[ ! $(grep -iP "${error_pattern}" "$logfile") ]]; then
echo -e "Backup completed: $target\n" &>>$logfile
else
echo -e "Backup failed: $target\n" &>>$logfile
ELAPSED="Elapsed: $(($SECONDS / 3600))hrs $((($SECONDS / 60) % 60))min $(($SECONDS % 60))sec"
echo -e "$ELAPSED" &>>$logfile
echo -e "****************** Backup failed ******************\n\n\n" &>>$logfile
cat $logfile >>$targz_repo/AllBackup.log
rm -rf $bk_dir
if [[ $broadcast == "TRUE" ]]; then
echo -e ">>> $(date +'%Y-%m-%d %H:%M:%S') Backup_targz(${backup_arr[*]}): Backup failed! Please check the log: $targz_repo/AllBackup.log" >>/etc/motd
fi
exit 1
fi
done
ELAPSED="Elapsed: $(($SECONDS / 3600))hrs $((($SECONDS / 60) % 60))min $(($SECONDS % 60))sec"
echo -e "$ELAPSED" &>>$logfile
echo -e "****************** Backup completed successfully ******************\n\n\n" &>>$logfile
cat $logfile >>$targz_repo/AllBackup.log
if [[ $broadcast == "TRUE" ]]; then
echo -e ">>> $(date +'%Y-%m-%d %H:%M:%S') Backup_targz(${backup_arr[*]}): Backup completed successfully! Snapshot: $tag" >>/etc/motd
fi