MySQL定时备份数据库操作示例

网络编程 2021-07-05 14:37www.168986.cn编程入门
这篇文章主要介绍了MySQL定时备份数据库操作,结合实例形式分析了MySQL定时备份数据库相关命令、原理、实现方法及操作注意事项,需要的朋友可以参考下

本文实例讲述了MySQL定时备份数据库操作。分享给大家供大家参考,具体如下

1. 查看mysqldump

root@laowang:/# which mysqldump
/usr/bin/mysqldump

2. 编写脚本

编辑my.f文件, 指定账号与密码, 然后在脚本中引用

root@laowang:/# vim /etc/my.f

[mysqldump]
user=root
password=root

脚本文件

root@laowang:/var/backups# vim mysql_backup.sh
#!/bin/sh
#################################################
# 备份数据库
#################################################
#mysqldump备份程序执行路径
DUMP=/usr/bin/mysqldump
#备份文件存放路径
OUT_DIR=/var/database
#备份文件所属权限
LINUX_USER=root
#要备份的数据库名字
DB_NAME=laowang
#备份的天数,之前的删除
DAYS=1

#进入备份存放目录
cd $OUT_DIR
#获取当前系统时间
DATE=`date +%Y_%m_%d`
#备份数据库的文件名
OUT_SQL=$DB_NAME"_$DATE.sql"
#最终保存的数据库备份文件名
TAR_SQL=$DB_NAME"_$DATE.tar.gz"
#开始执行备份数据库
$DUMP --defaults-extra-file=/etc/my.f --default-character-set=utf8 $DB_NAME > $OUT_SQL

#压缩为.tar.gz格式
tar -czf $TAR_SQL ./$OUT_SQL
#删除.sql格式的备份文件
rm $OUT_SQL
#更改备份数据库文件的所有者
chown $LINUX_USER:$LINUX_USER $OUT_DIR/$TAR_SQL
#删除30天前的备份文件(注意:{} \;中间有空格)
find $OUT_DIR -name ".tar.gz" -type f -mtime +$DAYS -exec rm -f {} \;

3. 定时计划

root@laowang:/# crontab -e
# m h dom mon dow  mand
10 10    /var/backups/mysql_backup.sh

ctrl+X 退出

y 保存修改

更多关于MySQL相关内容感兴趣的读者可查看本站专题《》、《》、《》、《》、《》及《》

希望本文所述对大家MySQL数据库计有所帮助。

Copyright © 2016-2025 www.168986.cn 狼蚁网络 版权所有 Power by