MySQLデータベースバックアップスクリプト(mysqldump)
1312 ワード
前言
次に共有するのはmysqldumpベースのmysqlデータベースバックアップスクリプトで、必要に応じて変更できます.(フルスタンバイでデータが大きい場合、dumpでバックアップされたファイルが1 Gより大きい場合は、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 {} \;
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 {} \;