博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
mysql备份脚本
阅读量:6031 次
发布时间:2019-06-20

本文共 2598 字,大约阅读时间需要 8 分钟。

在网上看了几个脚本根据网上的稍微修改了下,稍微更准确了点,就是缺少记录日志的功能,还没想好怎么写,后续添加

#!/bin/bash

#做大备份数量
Backup_Max_Files=20
#数据库备份目录
WORKING_DIR=$(dirname "$0")
export WORKING_DIR=$(cd -P "$WORKING_DIR"/ > /dev/null; pwd)
#数据库IP地址、帐号、密码
DB_Host="XXXXXXX"
DB_User="XXXXXX"
DB_Password="XXXXXXX"
#需要备份的数据库
Databases=(
"mysql"
"zabbix"
)

#==========

echo "###########Bash Shell MySql Databases Backup Tools!"

#定义变量=当前日期

Date_Time=$(date +%F)

#定义备份文件前缀

BackDataFile=zhang"${Date_Time}"
cd $WORKING_DIR
mkdir $BackData_File
#统计需要备份数据库的个数
count=0
while [ "x${Databases[count]}" != "x" ]
do
count=$((count + 1))
echo "Databases=$count"
done
echo "[+] ${count} The database is about to be backed up"

for Databases in ${Databases[@]}

do
echo "[+] MySql-backing up: ${Databases}"
echo -n " MySql Backup Start: "
echo $(date +"%Y-%m-%d %H:%M:%S")
#使用Mysqdump工具进行逻辑备份(全备)并使用邮件脚本发送成功失败提醒
if $(mysqldump -h${DB_Host} -u${DB_User} -p${DB_Password} --single-transaction --flush-logs mysql > ${BackData_File}/${Databases}.sql )
then
echo " Success OK!: Mysql database backup success!"
python /root/jiaoben/mail.py "y@163.com" "${Databases}数据库备份成功" "${Databases}>数据库备份成功"
else
echo " Error NO!: Failure of MySQL database backup!"
#python /root/jiaoben/mail.py "y@163.com" "${Databases}数据库备份失败" "${Databases}>数据库备份失败请查看"
fi
echo -n "Backup success: "
echo $(date +"%Y-%m-%d %H:%M:%S")
done
echo
echo "[+] Packaging and compressing folders with Tar ...."
#使用tar命令打包并压缩生成的数据库文件
cd $WORKING_DIR
tar -cv ${BackData_File} | bzip2 > ${BackData_File}.tar.bz2 && rm -rf ${BackData_File}
#删除n天以前备份的数据文件

echo "[+] Delete over time database backup files ...."

find $WORKINGDIR -name "zhang*.tar.bz2" -mtime +${Backup_Max_Files} -exec rm -rf {} \;

#find $WORKINGDIR -name "zhang*.tar.bz2" -mtime +${Backup_Max_Files} -exec ls {} \;

后补:邮件报警脚本(网络版,已测试可以使用没有问题)

#!/usr/bin/python
coding=utf-8

#测试方法:python 5.py XXXXX@163.com test test

#能正常发送邮件说明成功
import smtplib
import sys
from email.mime.text import MIMEText

class send_mail():mail_user="XXXXXX@163.com"

br/>mail_host="smtp.163.com"
mail_user="XXXXXX@163.com"
#此出不是登录密码。而是开头smtp的登录口令
mail_pass="XXXXXx"
mail_postfix="163.com"
def init(self,sub,content):

def sendMessage(self,user):    self.msg['To'] = ";".join(user)    try:        s = smtplib.SMTP_SSL(host=self.mail_host,port=465)        s.login(self.mail_user,self.mail_pass)        s.sendmail(self.me, user, self.msg.as_string())

#发送邮件

s.close()
except Exception, e:
print str(e)

if name == 'main':

mailto_list=[]
mailto_list.append(sys.argv[1])
s = send_mail(sys.argv[2],sys.argv[3])
s.sendMessage(mailto_list)

转载于:https://blog.51cto.com/bosszhang/2059523

你可能感兴趣的文章
一次 JVM 调优的笔记
查看>>
9s12
查看>>
Track与nqa联动 VS 静态路由优先级相同
查看>>
maven打包跳过Test
查看>>
Android 开源项目集合
查看>>
mysql 命令行小结
查看>>
说一下fopen和open
查看>>
12月28日二周四次【Python基础语法】
查看>>
并发编程2:认识并发编程的利与弊
查看>>
MySQL(mysql 5.7)用户密码的管理
查看>>
学习笔记第三十一节课
查看>>
六周第三次课 9.6/9.7 awk
查看>>
【VMware vSAN 6.6】5.1.基于存储策略的管理:vSAN硬件服务器解决方案
查看>>
我为什么看好IPFS
查看>>
【Ansible】3个让Ansible性能飞起的简单优化方案!
查看>>
在mac上安装 docker
查看>>
rsyslog日志管理+LogAnalyzer
查看>>
man命令详解
查看>>
linux发行版本
查看>>
网站被黑搜索快照被劫持怎么办
查看>>