centos mysql数据库自动备份

前端之家收集整理的这篇文章主要介绍了centos mysql数据库自动备份前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

方案一:

1.创建并编辑文件 /usr/sbin/bakMysqL,命令:

vi /usr/sbin/bakMysqL

内容如下:

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"

注意 -p 和$db_passwd之间没有空格,不然$db_passwd会被当做参数[数据库名]来解析

2.修改文件bakMysqL属性,使其可执行;

chmod +x /usr/sbin/bakMysqL

3.创建定时任务@H_301_27@

crontab –e

#进入编辑界面,内容如下@H_301_27@

00 23 * * * ./usr/sbin/bakMysqL

#上一行命令的 " . " 不要也可

# 00 23是每天23:00执行 bakMysqL文件,备份数据库在路径/usr/software/backup/MysqLbackup下

service crond restart@H_301_27@

这种方案我试过,可以成功!

方案二:

步骤如下

建备份文件夹:

?

1

mkdir@H_301_27@ MysqL_data_bak@H_301_27@

建脚本文件

?

1

touch@H_301_27@ autobackupMysqL.sh@H_301_27@

打开文件

?

1

vi@H_301_27@ autobackupMysqL.sh@H_301_27@

在脚本中加入如下内容

?

1

2

filename=`@H_301_27@date@H_301_27@ +%Y%m%d`@H_301_27@

/usr/bin/MysqLdump@H_301_27@ -uroot -proot boss >>@H_301_27@/home/MysqL_data_bak/@H_301_27@$filename.sql@H_301_27@

检查有没安装crond,如果没有,先安装

?

1

2

yum -y @H_301_27@install@H_301_27@ vixie-@H_301_27@cron@H_301_27@

yum -y @H_301_27@install@H_301_27@ crontabs@H_301_27@

启动服务 :service crond start@H_301_27@

在CentOS系统中加入开机自动启动: chkconfig --level 345 crond on@H_301_27@

?

1

crontab@H_301_27@ -e@H_301_27@

加入内容:00 03 * * * source /root/autobackupMysqL.sh@H_301_27@

每天凌晨3点运行此文件,对数据库进行备份

?

1

service crond restart@H_301_27@

好了,以上就完成了。

猜你在找的CentOS相关文章