1.创建并编辑文件 /usr/sbin/backmysql,命令:
vi /usr/sbin/backmysql
/usr/sbin/backmysql 该路径可自定义
内容如下:
1 db_user="root"
2 db_passwd="root"
3 db_name="db_test"
4 # the directory for story your backup file.you shall change this dir
5 backup_dir="/usr/software/backup/mysqlbackup"
6 # date format for backup file (dd-mm-yyyy)
7 time="$(date +"%Y%m%d%H%M%S")"
8
9 /绝对路径/mysqldump -u$db_user -p$db_passwd $db_name > "$backup_dir/$db_name"_"$time.sql"
#压缩文件
/usr/local/mysql/bin/mysqldump -u$db_user -p$db_passwd $db_name | gzip > "$backup_dir/$db_name"_`date +%Y-%m-%d_%H%M%S`.sql.gz
#文件保存30天
find $backup_dir -name $db_name"_*.sql.gz" -type f -mtime +30 -exec rm -rf {} \; > /dev/null 2>&1
注意 -p 和 $db_passwd之间没有空格,不然$db_passwd会被当做参数[数据库名]来解析
/绝对路径/mysqldump 这个必须是绝对路径,不然生成的备份文件为空(本人就在这里栽跟头了)
db_user="root" //用户名
db_passwd="root"//密码
db_name="db_test"//数据库名
2.修改文件backmysql属性,使其可执行;
chmod +x /usr/sbin/backmysql
3.创建定时任务
crontab –e
#进入编辑界面,内容如下
00 23 * * * ./usr/sbin/backmysql
#上一行命令的 " . " 不要也可
# 00 23 是每天23:00执行 bakmysql 文件,备份数据库在路径 /usr/software/backup/mysqlbackup下
做记录供以后参考(=.=)
service crond start 启动
service crond restart 重启
service crond stop 停止
chkconfig --level 345 crond on 自启服务