MySQL备份脚本(包含zabbix数据库)
admin
2023-05-27 12:41:40
0

需求:按天备份,保留一周,zabbix数据库不备份历史数据

MySQL版本:5.7.17

脚本:

需要提前建立路径
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)过程略。

[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


相关内容

热门资讯

湖南石门强降雨搜救持续:村民守... 澎湃新闻记者 廖艳 实习生 林霄自5月17日7时起,湖南常德石门县遭遇极端强降雨天气,瞬时雨量大、致...
美新远程空空导弹初露真容,能缓... 澎湃新闻特约撰稿 王若鸿近日,美国一位航空摄影师拍摄到几架从佛罗里达州埃格林空军基地起飞的美国海军测...
官方通报福建漳州“泡药杨梅”事... 【大河财立方消息】 5月20日晚,福建漳州市食品安全委员会办公室通报:5月15日,媒体报道反映漳州市...
山河湖海,算算生态环境的“三本... 【大河财立方 记者 程帅星 北京报道】 5月20日下午,国务院新闻办公室举行2026年“新征程上的奋...
官方通报“儿童乳膏涉嫌非法添加... 【大河财立方消息】针对今年3月媒体反映广西十安生物科技有限公司生产的“消字号”产品涉嫌非法添加问题,...
山西通报“明长城被露天煤矿长期... 5月20日,山西宁武县委宣传部发布情况通报:近日,有媒体报道神达朝凯煤业相关问题。宁武县委、县政府高...
国务院被掏空,美国外交陷入“空... ◆在美国国务卿鲁比奥的主导下,国务院正全面围绕特朗普的核心议程进行改革。(图源:美联社)文/方晨宇编...
美军“尼米兹”号航母进入加勒比... 新华社华盛顿5月20日电(记者黄强 徐剑梅)美军南方司令部20日在社交媒体发布消息说,美军“尼米兹”...
28个暴雨红色预警信号生效中,... 20日晚,粤西到珠三角南部一带强降水仍在持续,暖湿气流源源不断补充,导致新生成的强降雨云团不断在同一...
中构建筑取得钢结构厂房用可伸缩... 国家知识产权局信息显示,中构建筑有限公司取得一项名为“一种钢结构厂房用可伸缩式抗风支撑杆”的专利,授...