脚本放在 /home/user/@R_403_198@_backup.sh
crontab
# crontab -l
# m h dom mon dow command
28 16 * * * /home/user/@R_403_198@_backup.sh
脚本如下
#!/bin/sh
# @R_403_198@_backup.sh: backup @R_403_198@ databases and keep newest 5 days backup.
#
# Last updated: 20 March 2006
# ----------------------------------------------------------------------
# This is a free shell script under GNU GPL version 2.0 or above
# Copyright (C) 2006 Sam Tang
# Feedback/comment/suggestions : http://www.real-blog.com/
# ----------------------------------------------------------------------
# your @R_403_198@ login information
# db_user is @R_403_198@ username
# db_passwd is @R_403_198@ password
# db_host is @R_403_198@ host
# -----------------------------
db_user="root"
db_passwd="password"
db_host="localhost"
# the directory for story your backup file.
backup_dir="/home/mybackup"
# date format for backup file (dd-mm-yyyy)
time="$(date +"%d-%m-%Y")"
# @R_403_198@,@R_403_198@dump and some other bin's path
@R_403_198@="/usr/local/@R_403_198@/bin/@R_403_198@"
@R_403_198@DUMP="/usr/local/@R_403_198@/bin/@R_403_198@dump"
MKDIR="/bin/mkdir"
RM="/bin/rm"
MV="/bin/mv"
GZIP="/bin/gzip"
# check the directory for store backup is writeable
test ! -w $backup_dir && echo "Error: $backup_dir is un-writeable." && exit 0
# the directory for story the newest backup
test ! -d "$backup_dir/backup.0/" && $MKDIR "$backup_dir/backup.0/"
# get all databases
all_db="$($@R_403_198@ -u $db_user -h $db_host -p$db_passwd -Bse 'show databases')"
for db in $all_db
do
$@R_403_198@DUMP -u $db_user -h $db_host -p$db_passwd $db | $GZIP -9 > "$backup_dir/backup.0/$time.$db.gz"
done
# delete the oldest backup
test -d "$backup_dir/backup.5/" && $RM -rf "$backup_dir/backup.5"
# rotate backup directory
for int in 4 3 2 1 0
do
if(test -d "$backup_dir"/backup."$int")
then
next_int=`expr $int + 1`
$MV "$backup_dir"/backup."$int" "$backup_dir"/backup."$next_int"
fi
done
exit 0;
备注:
@R_403_198@是以@R_403_198@用户身份运行的,对/home /mybackup不可写也会失败
chmod 777 /home/mybackup问题解决了
总结
如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
小编个人微信号 jb51ccc
喜欢与人分享编程技术与工作经验,欢迎加入编程之家官方交流群!