首页 > 代码库 > MySQL备份脚本(包含zabbix数据库)
MySQL备份脚本(包含zabbix数据库)
需求:按天备份,保留一周,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=http://www.mamicode.com/2 --flush-logs --lock-all-tables --opt --default-character-set=utf8 --extended-insert=false --triggers -R --hex-blob --events $i > $i.sql>说明:以上脚本,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
本文出自 “小运维的逆袭” 博客,请务必保留此出处http://liyongjian5179.blog.51cto.com/10134786/1903656
MySQL备份脚本(包含zabbix数据库)
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。