需求:按天備份,保留一週,zabbix數據庫不備份歷史數據mysql
MySQL版本:5.7.17sql
腳本:數據庫
須要提早創建路徑 mkdir -pv /opt/mysql_backup/auto_backup cat /opt/mysql_backup/mysqlback.sh
#!/bin/bash # 0 3 * * * bash /opt/mysql_backup/mysqlback.sh &>/dev/null DBUSER=root DBPASS=********** DATE=`date +%Y-%m-%d` BACKPATH="/opt/mysql_backup/auto_backup"HOSTNAME=`/bin/hostname` MYSQL_BACK_DIR="$BACKPATH/${HOSTNAME}_$DATE"MYSQLDUMP=/usr/bin/mysqldump MYSQL=/usr/bin/mysql TAR_DIR=$DATETAR=/bin/tar RM=/bin/rm FIND=/bin/find DSTIP=192.168.100.131 #If no directory then create the directory if [ ! -d $MYSQL_BACK_DIR ];then mkdir -p $MYSQL_BACK_DIR fi #delete 7 day ago file #lock tables #$MYSQL -u$DBUSER -p$DBPASS -h$DBHOST -e "stop slave;" #$MYSQL -u$DBUSER -p$DBPASS -h$DBHOST -e "flush tables with read lock;" #list mysql databases and dump database for i in $($MYSQL -u$DBUSER -p$DBPASS -e "show databases\G"|grep Database|grep -v schema|grep -v zabbix|grep -v sys|awk '{print $2}') do cd $MYSQL_BACK_DIR $MYSQLDUMP -u$DBUSER -p$DBPASS --master-data=2 --flush-logs --lock-all-tables --opt --default-character-set=utf8 --extended-insert=false --triggers -R --hex-blob --events $i > $i.sql # $MYSQLDUMP -u$DBUSER -p$DBPASS -h$DBHOST --single-transaction --master-data=2 $i |gzip > $i.sql done #Backup Zabbix Configuration files. cd $MYSQL_BACK_DIR $MYSQLDUMP -u$DBUSER -p$DBPASS --master-data=2 --flush-logs --lock-all-tables --opt --default-character-set=utf8 --extended-insert=false --triggers -R --hex-blob --events zabbix \ --ignore-table=zabbix.alerts \ --ignore-table=zabbix.auditlog \ --ignore-table=zabbix.auditlog_details \ --ignore-table=zabbix.escalations \ --ignore-table=zabbix.events \ --ignore-table=zabbix.history \ --ignore-table=zabbix.history_log \ --ignore-table=zabbix.history_str \ --ignore-table=zabbix.history_str_sync \ --ignore-table=zabbix.history_sync \ --ignore-table=zabbix.history_text \ --ignore-table=zabbix.history_uint \ --ignore-table=zabbix.history_uint_sync \ --ignore-table=zabbix.trends \ --ignore-table=zabbix.trends_uint > zabbix.sql #unlock tables #tar backfile and rm oldfile cd $BACKPATH $TAR czf $MYSQL_BACK_DIR.tar.gz ${HOSTNAME}_${DATE} > /dev/null 2>&1 scp $MYSQL_BACK_DIR.tar.gz $DSTIP:/opt/mysql_backup/auto_backup $RM -rf ${HOSTNAME}_${DATE} $FIND $BACKPATH -mtime +7 -exec $RM -rf {} \;
說明:以上腳本,zabbix數據庫單獨拎出來了,只須要備份配置表,不須要備份歷史數據,若是mysql上沒有zabbix數據庫, 那一大段能夠註釋掉,異地備份須要設置免密鑰登陸,不然scp過程須要人工輸入密碼,致使執行等待;或者使用expect進行捕捉,自動添加密碼(須要先安裝expect)過程略。bash
[lyj@lyj.com mysql_backup]$ pwd/opt/mysql_backup [lyj@lyj.com mysql_backup]$ tree . ├── auto_backup │ └── server5_2017-03-06.tar.gz #備份後的文件名稱格式爲「主機名_日期.tar.gz」 ├── mysql_backup.sh └── readme 1 directory, 3 files