MySQL数据库备份脚本(mysqldump)

前言


下面分享的是一个基于mysqldump的mysql数据库备份脚本,可根据需求更改。
(如全备,且数据较大,dump备份出的文件大于1G,建议使用xtrabackup备份,还原方便)。

更多mysqldump备份技巧请参考下列链接:
https://blog.csdn.net/GX_1_11_real/article/details/81062074



cat backup_3306.sh



#!/bin/bash

source /root/.bash_profile

DATE=`date +%Y%m%d`
DBUSER=root
DBPASSWORD=@#$DSfw146y5s
BACKUPDIR=/data/backup/mysql_3306/$DATE
SOCKET=$(grep socket /etc/my.cnf | awk -F= '{print $2}' | sed 's/ //g' | uniq)
log=/data/backup/logs/


test -d $BACKUPDIR || mkdir -p $BACKUPDIR

#下列命令为将所有的库拆分开备份为xz文件 
mysqldump  -u$DBUSER -p$DBPASSWORD -S $SOCKET  --default-character-set=utf8 --skip-comments --add-drop-database --master-data=1 --flush-logs --opt  -A | xz -zf   > $BACKUPDIR/dbbackup.sql.xz

#下列命令为将所有的库备份为一个sql文件 
#mysqldump -u$DBUSER -p$DBPASSWORD -S $SOCKET  --all-databases  --skip-lock-tables  --single-transaction --master-data=2 --flush-logs  >  all.sql

CUR=`du -k $BACKUPDIR/dbbackup.sql.xz | awk '{print $1}'`
if [ "$CUR" -lt "500000" ];then
             echo  "dbbackup is failed" > $log/mysql.$DATE.log
else
    	     echo  "dbbackup is success" > $log/mysql.$DATE.log
fi 

#删除备份目录下,前7天的备份文件    
find $BACKUPDIR  -type f -mtime +7 -exec rm -rf {} \;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

漠效

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值