作者:手机用户2502853355 | 来源:互联网 | 2023-05-18 17:26
数据备份是一个项目必需的工作,保证数据库出问题时,将损失减小到最低。本文记录下linux服务器中使用脚本对MYSQL数据备份,并且定时清除7天前的备份。crontab定时备份1、创建备份目录#ro
数据备份是一个项目必需的工作,保证数据库出问题时,将损失减小到最低。本文记录下linux服务器中使用脚本对MYSQL数据备份,并且定时清除7天前的备份。
crontab定时备份
1、创建备份目录
# root 用户,创建备份目录
mkdir -p /bak/mysqlbak
cd /bak/mysqldata
2、编写运行脚本
vi /usr/sbin/bakmysql.sh
脚本代码:
#!/bin/bash
# Name:bakmysql.sh
# This is a ShellScript For Auto DB Backup and Delete old Backup
#
backupdir=/bak/mysqlbak
time=` date +%Y%m%d%H `
/usr/local/mysql/bin/mysqldump -h rm***aliyuncs.com -u root -p*** huishi | gzip > $backupdir/huishi$time.sql.gz
#
find $backupdir -name "huishi*.sql.gz" -type f -mtime +7 -exec rm {} ; > /dev/null 2>&1
#说明:
1)此处的/usr/local/mysql/bin/是mysqldump命令所在的绝对路径
2)-h 主机地址 对于本地数据库默认是localhost,远程的数据库服务器,则填写具体地址
3)最后一句表示删除文件更改时间距现在7天以前的数据备份文件
3、为脚本添加执行权限
# chmod +x /usr/sbin/bakmysql.sh
4、设置crontab定时执行
vi /etc/crontab
#在最后一行中加入:
00 3 * * * root /usr/sbin/bakmysql.sh
#表示每天3点00分执行备份
#如果是每五分钟执行一次可改为:*/5 * * * * root /usr/sbin/bakmysql.sh
注:crontab配置文件格式如下:
分 时 日 月 周 命令
5、重启crontab
service crond restart
6、验证查看
在定时执行的命令完成后,可点击目录查看是否有有文件正确生成
cd /bak/mysqlbak
ls -a