1、编写数据本分脚本 my_dbbak.sh
#/bin/bash
dbuser=root
dbpassword=mypass
#dbhost=127.0.0.1
#dbname=(gee_business gee_operate gee_person)
dbname=mydb
dbback=/var/databackup/mysql_db/
date=`date +%F_%T`
if [ ! -d "$dbback" ];then
mkdir -p "$dbback"
fi
for db in ${dbname[*]}
do
/usr/local/mysql/bin/mysqldump -u$dbuser -p$dbpassword $dbname > $dbback$dbname$date.sql
find $dbback -mtime +1000 -name "*.sql" -exec rm -rf {} \;
done
echo "Your Database Backup Successfully Completed"
find 后面紧跟的是要查找的目录,. 表示当前目录
-type f:指定查找对象为文件
-name *.log:指定查找对象名称以.log结尾
-mtime +180: 查找180天以前的老文件
-exec rm {} \; :执行删除命令,这句长得很奇怪,后面有个 {} \; 是必须的,也可以执行其他指令,比如ls, rm -i之类的
2、为my_dbbak.sh增加执行权限chmod +x my_dbbak.sh
3、linux添加定时任务
编辑定时任务列表
crontab -e
添加定时任务
0 1 * * * /usr/my_dbbak.sh
保存后
查看是否添加成功
crontab -l
4、查看定时任务服务状态
service crond status
如果未启动则执行service crond start