Jtti Jtti Jtti Jtti
mysqldump+crontab定时备份mysql数据库,及恢复步骤 | VPS精选网

mysqldump+crontab定时备份mysql数据库,及恢复步骤

新手指南 6年前 (2019-08-04) 4008次浏览

对于站长来说,数据库备份是必不可少的。备份就像买保险一样,平时不觉得有什么,但是一旦出现问题,绝对会成为你的救命稻草。整理了一个 mysql 数据库定时备份脚本,可以实现每天定时备份数据库,清理过期备份文件,备份日志等功能。

数据库的数据基本每天都会变化,所以一般每天都会备份一次数据。会用到 corntab 和 mysqldump 这两个工具。corntab 负责定时执行任务,mysqldump 负责将 mysql 数据备份到文件中。

基于 mysqldump 的备份数据库的脚本

#!/bin/bash
number=30 #保存备份个数
backup_dir=/root/mysqlbackup #备份保存路径
dd=`date +%Y%m%d%H%M%S` #日期格式
tool=mysqldump
username=root #用户名
password=123456 #密码
database_name=sample #将要备份的数据库名称
$tool -u $username --default-character-set=utf8 -p$password $database_name > $backup_dir/$database_name-$dd-utf8.dump
#写创建备份日志
echo "create $backup_dir/$database_name-$dd.dump" >> $backup_dir/log.txt
#找出需要删除的备份
delfile=`ls -l -crt  $backup_dir/*.dump | awk '{print $9 }' | head -1`
#判断现在的备份数量是否大于$number
count=`ls -l -crt  $backup_dir/*.dump | awk '{print $9 }' | wc -l`
if [ $count -gt $number ]
    then
        rm $delfile
        echo "delete $delfile" >> $backup_dir/log.txt
fi

以上脚本可以实现备份指定日期的数据库文件,超过一定日期的备份文件自动删除。还自带每日备份日志。需要根据自己的情况配置 mysql 用户名、密码、数据库名称、备份文件保存路径、保存备份文件数量。再将脚本保存为文件如/mysql_bakup.sh

通过 crontab 实现定时执行脚本

如每天晚上 10 点自动备份数据库,其中/mysql_bakup.sh 是 mysql 备份脚本。

执行 corntab -e,加入以下命令

0 22 * * * bash /mysql_bakup.sh

mysql 数据库恢复步骤

1 进入数据库
mysql -u root -p
2 创建数据库
create db_name;
3 恢复数据库,其中 mysql_bak.sql 是备份文件
source /mysql_bak.sql

注 :技术交流,获取 VPS 最新补货通知、折扣活动请加 QQ 群:283468775

VPS 精选网 , 版权所有丨如未注明 , 均为原创丨
转载请注明原文链接:mysqldump+crontab 定时备份 mysql 数据库,及恢复步骤
喜欢 (0)