1.先编写一个脚本,脚本所在目录自己定义
#!/bin/bash
#备份目的文件目录
BACKUP=/data/backup/db
#获取时间
DATETIME=$(date +%Y-%m-%d_%H%M%S)
#数据库地址
HOST=localhost
#数据库用户名
DB_USER=root
#数据库密码
DB_PW=mysql
#备份的数据库
DATABASE=hspedo
#创建备份的目录,如果不存在,就创建
#注:&&表示条件判断,前边成立,后边执行,前边不成立,后边不执行 []常用于判断,同test。
[ ! -d "${BACKUP}/${DATETIME}" ] && mkdir -p "${BACKUP}/${DATETIME}"
#备份数据库 注:mysqldump是mysql自带的逻辑备份工具,参数详见 musqldump --help
mysqldump -u${DB_USER} -p${DB_PW} --host=${HOST} -q -R --databases ${DATABASE} | gzip > ${BACKUP}/${DATETIME}/${DATETIME}.sql.gz
#将文件处理成tar.gz
cd ${BACKUP}
tar -zcvf $DATETIME.tar.gz $DATETIME
#删除对应的备份目录
#rm -rf $BACKUP/$DATETIME
#删除10天前备份的文件
#atime说明:-atime/-mtime/-ctime 均为与时间有关的参数,+10 十天以前, -10 十天以内,10 第十天
#-exec说明:find命令执行的结果放到{},-exec \;是关键字部分,是额外执行的命令
find $BACKUP -atime +10 -name "*.tar.gz" -exec rm -rf {} \;
2.放入定时任务中
crontab -e
* 1 * * * 脚本目录的绝对路径