您的位置:首页 > 数码常识数码常识
Mysql数据库备份脚本(mysql数据库备份数据)
2025-05-13人已围观
Mysql数据库备份脚本(mysql数据库备份数据)
一、知识储备工作:
mysql数据库备份数据
Mysql导出数据库语法:
shell脚本if条件判断基本语法gzip压缩文件用法rsync异地备份用法:ssh免密登录二、场景
本次利用shell脚本实现以下需求:
每天凌晨3点执行备份,需备份所有库备份的数据存放在本地/data/backup下将所有备份文件压缩,格式为gzip压缩后的名称格式示例:mysql_bak.tar.gz利用rsync实现异地备份本地备份数据保留30天三、MySQL数据库备份脚本
#!/bin/bash
#date: 20220120
set -e #错误时,便停止执行脚本
#数据库名,可以添加多个
EXCLUDE="Database|mysql|information_schema|performance_schema|sys"
USER="root"
PASSWORD="123456"
BACKUP_DIR=/data/backup
LOGFILE=/data/backup/data_backup.log
DATE=`date +%Y%m%d_%H%M`
cd $BACKUP_DIR
#写入日记文件
echo "--------------------" >> $LOGFILE
echo "BACKUP DATE:" $(date +"%y-%m-%d %H:%M:%S") >> $LOGFILE
echo "-------------------" >> $LOGFILE
mysql -uroot -p${PASSWORD} -e "show databases"|grep -Ev ${EXCLUDE}|xargs mysqldump -uroot -p${PASSWORD} --routines --single_transaction --master-data=2 --databases > xzmysql_bak${DATE}.sql
if [ $?==0 ];then
echo "$DATE--Database is backup succeed" >> $LOGFILE
else
echo "Database Backup Fail!" >> $LOGFILE
fi
cd $BACKUP_DIR
tar -czf xzmysql_bak${DATE}.tar.gz xzmysql_bak${DATE}.sql
rm -rf xzmysql_bak${DATE}.sql
#全部成功就同步到异地备份服务器
if [ $?==0 ];then
rsync -avz --progress --password-file=/etc/rsync.password --exclude={*.log,*.txt} ${BACKUP_DIR}/* rsync_backup@192.168.10.51::xzmysqlbackup/192.168.10.128/
else
echo "Database Backup Fail!" >> $LOGFILE
fi
#删除30天以上的备份文件
find $BACKUP_DIR -type f -mtime +30 -name "*.gz" -exec rm -f {} ;
上面就是小居数码小编今天给大家介绍的关于(mysql数据库备份数据)的全部内容,希望可以帮助到你,想了解更多关于数码知识的问题,欢迎关注我们,并收藏,转发,分享。
94%的朋友还想知道的:
手把手教你操作(微信聊天记录怎么备份迁移到另一台手机)
10款最出色的免费数据库管理工具推荐(免费数据库管理工具)
电脑上qq聊天记录怎么备份图文演示(电脑qq聊天记录如何备份)
u8财务软件数据备份步骤分享(u8财务软件备份在哪里)
154521
一、知识储备工作:
mysql数据库备份数据
Mysql导出数据库语法:
shell脚本if条件判断基本语法gzip压缩文件用法rsync异地备份用法:ssh免密登录二、场景
本次利用shell脚本实现以下需求:
每天凌晨3点执行备份,需备份所有库备份的数据存放在本地/data/backup下将所有备份文件压缩,格式为gzip压缩后的名称格式示例:mysql_bak.tar.gz利用rsync实现异地备份本地备份数据保留30天三、MySQL数据库备份脚本
#!/bin/bash
#date: 20220120
set -e #错误时,便停止执行脚本
#数据库名,可以添加多个
EXCLUDE="Database|mysql|information_schema|performance_schema|sys"
USER="root"
PASSWORD="123456"
BACKUP_DIR=/data/backup
LOGFILE=/data/backup/data_backup.log
DATE=`date +%Y%m%d_%H%M`
cd $BACKUP_DIR
#写入日记文件
echo "--------------------" >> $LOGFILE
echo "BACKUP DATE:" $(date +"%y-%m-%d %H:%M:%S") >> $LOGFILE
echo "-------------------" >> $LOGFILE
mysql -uroot -p${PASSWORD} -e "show databases"|grep -Ev ${EXCLUDE}|xargs mysqldump -uroot -p${PASSWORD} --routines --single_transaction --master-data=2 --databases > xzmysql_bak${DATE}.sql
if [ $?==0 ];then
echo "$DATE--Database is backup succeed" >> $LOGFILE
else
echo "Database Backup Fail!" >> $LOGFILE
fi
cd $BACKUP_DIR
tar -czf xzmysql_bak${DATE}.tar.gz xzmysql_bak${DATE}.sql
rm -rf xzmysql_bak${DATE}.sql
#全部成功就同步到异地备份服务器
if [ $?==0 ];then
rsync -avz --progress --password-file=/etc/rsync.password --exclude={*.log,*.txt} ${BACKUP_DIR}/* rsync_backup@192.168.10.51::xzmysqlbackup/192.168.10.128/
else
echo "Database Backup Fail!" >> $LOGFILE
fi
#删除30天以上的备份文件
find $BACKUP_DIR -type f -mtime +30 -name "*.gz" -exec rm -f {} ;
上面就是小居数码小编今天给大家介绍的关于(mysql数据库备份数据)的全部内容,希望可以帮助到你,想了解更多关于数码知识的问题,欢迎关注我们,并收藏,转发,分享。
94%的朋友还想知道的:
手把手教你操作(微信聊天记录怎么备份迁移到另一台手机)
10款最出色的免费数据库管理工具推荐(免费数据库管理工具)
电脑上qq聊天记录怎么备份图文演示(电脑qq聊天记录如何备份)
u8财务软件数据备份步骤分享(u8财务软件备份在哪里)
154521
很赞哦! ()