linux下实现mysql定时自动备份数据

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 自启服务

猜你喜欢

转载自blog.csdn.net/weixin_42389328/article/details/83820046
今日推荐