linux 定时备份mysql
定时备份:
1、创建备份文件存放目录
2、创建备份脚本backup.sh
#!/bin/bash
DBUser=db_back
DBPasswd=password
DBName=db_name
SERVER=localhost
save_dir=/dbbackup/
LogFile="$save_dir"backup.log
NewFile="$save_dir"$DBName'_'$(date +%Y%m%d).sql
OldFile="$save_dir"$DBName'_'$(date +%Y%m%d --date='30 days ago').sql
if [ -f $OldFile ]
then
rm -f $OldFile >> $LogFile 2>&1
echo "[$OldFile]Delete Old File Success!" >> $LogFile
else
echo "[$OldFile]No Old Backup File!" >> $LogFile
fi
if [ -f $NewFile ]
then
echo "[$NewFile]The Backup File is exists,Can't Backup!" >> $LogFile
echo "Begin ro recover the data...."
echo "Data has been restored!" >>$LogFile
else
mysqldump -h$SERVER -u$DBUser -p$DBPasswd --default-character-set='utf8' --quick --single-transaction -R $DBName >$NewFile
echo "[$NewFile]Backup Success!" >> $LogFile
fi
3、使脚本可执行
4、修改/etc/crontab
crontab -e
00 22 * * * /absolute/path/to/backup.sh 每天22点定时备份
crond是linux下用来周期性的执行某种任务或等待处理某些事件的一个守护进程,默认会安装此服务工具,并且会自动启动crond进程,
crond进程每分钟会定期检查是否有要执行的任务,如果有要执行的任务,则自动执行该任务。
crontab是控制计划任务的命令。
crontab [-u user] [ -e | -l | -r ]
以root身份查看/编辑/删除当前用户的crond服务配置,如果加上 -u USERNAME则操作指定用户的crond服务配置。
Linux下的任务调度分为两类,系统任务调度和用户任务调度。
系统任务调度:系统周期性所要执行的工作,比如写缓存数据到硬盘、日志清理等。在/etc目录下有一个crontab文件,这个就是系统任务调度的配置文件。
用户任务调度:用户定期要执行的工作,比如用户数据备份、定时邮件提醒等。所有用户定义的crontab 文件都被保存在 /var/spool/cron目录中。其文件名 与用户名一致。
查看crond服务是否已设置为开机启动,执行命令:ntsysv
加入开机自动启动:chkconfig –level 35 crond on
root身份 service crond reload 重新载入配置
root身份 service crond status 查看服务状态
星号(*):代表所有可能的值,例如month字段如果是星号,则表示在满足其它字段的制约条件后每月都执行该命令操作。
逗号(,):可以用逗号隔开的值指定一个列表范围,例如,“1,2,5,7,8,9”
中杠(-):可以用整数之间的中杠表示一个整数范围,例如“2-6”表示“2,3,4,5,6”
正斜线(/):可以用正斜线指定时间的间隔频率,例如“0-23/2”表示每两小时执行一次。同时正斜线可以和星号一起使用,例如*/10,如果用在minute字段,表示每十分钟执行一次。