zoukankan      html  css  js  c++  java
  • 使用shell自动备份数据库

    全备份

    #!/bin/sh
    #mysql地址
    #检测用户是否手动输入了密码
    mysql_host=""
    
    #mysql用户
    mysql_user=""
    
    #mysql密码
    mysql_password=""
    
    #mysql数据库名
    
    #如果不填写需要导出的数据库名称提示错误信息并终止执行,注意[]里面两边必须有空格
    if [ ! -n "$1" ];then
        echo "您没有输入数据库名称"
        echo "格式:xxx.sh 数据库名称"
        exit
    fi
    mysql_name="$1"
    
    #mysql安装路径
    mysql_path="/usr/bin/"
    
    #备份文件存放路径
    bak_path="/root/shell/mysqlBak/${mysql_name}"
    
    #删除过期数据 true代表是 false代表否
    delete_overdue_data="true"
    
    #删除多少天前数据 默认30天
    delete_overdue_data_days=30
    
    #检测目录是否存在,如果不存在自动创建目录
    if [ ! -x "${bak_path}" ];then
        mkdir "${mysql_name}"
        chmod 755 "${bak_path}"
    fi
    
    #备份时间
    bak_date=`date +%F`
    ${mysql_path}/mysqldump --opt -u${mysql_user} -p${mysql_password} -h${mysql_host} ${mysql_name} | gzip > ${bak_path}/${bak_date}.sql.gz
    
    #检测是否删除过期数据
    if [ "${delete_overdue_data}" != "true" ];then
        echo "备份数据完成..."
        exit
    fi
    #删除过期备份数据
    #获取今天日期
    the_date_today=`date +%Y%m%d`
    
    #获取要删除的文件
    find_date_file=`date -d "${the_date_today} ${delete_overdue_data_days} days ago" "+%Y-%m-%d"`
    
    #进入指定目录
    cd ${bak_path}
    #查找要删除的数据
    ls -l|grep ${find_date_file}
    #取得查找结果0不存在 1存在
    result=$?
    echo ${result}
    if [ ${result} == 0 ];then
        echo "删除过期数据"
        `rm -f ${find_date_file}.*`
    fi

    全量备份

    #!/bin/bash
    # Name:qbk全备份脚本
    # mysql qbk scripts
    # By zxsdw.com
    # Last Modify:2015-01-21
    #定义脚本存放路径
    #scriptsDir=/usr/sbin
    #定义用户名及密码
    user=root
    userPWD=密码
    #定义要备份的数据库
    database=数据库
    #定义完全备份文件存放路径
    bakDir=/backup/mysql
    #eMailFile=$bakDir/email.txt
    #eMail=admin@zxsdw.com
    #定义日志文件
    LogFile=$bakDir/mysqlbak.log
    DATE=`date +%Y%m%d`
    echo " " >> $LogFile
    echo " " >> $LogFile
    echo "--------------------------" >> $LogFile
    echo $(date +"%y-%m-%d %H:%M:%S") >>$LogFile
    echo "-----------------" >> $LogFile
    cd $bakDir
    DumpFile=$DATE.sql.gz
    mysqldump --flush-logs -u$user -p$userPWD --quick $database| gzip >$DumpFile
    echo "Dump Done" >> $LogFile
    echo  "[$DumpFile]Backup Success!" >> $LogFile
    daily_databakDir=$bakDir/daily_backup
    cd $bakDir/daily_backup
    find $daily_databakDir -name "daily*" -type f -mtime +35 -exec rm {} ; > /dev/null 2>&1
    

      

    增量备份脚本:

    #!/bin/bash
    # Name:zbk增量备份
    # mysql zbk scripts
    # By zxsdw.com
    # Last modify:2015-01-21
    
    
    #定义数据库用户名及密码
    user=root
    userPWD=密码
    #定义数据库
    database=数据库
    #生成一个新的mysql-bin.00000X文件,如果err日志被清除,则自动新建一个。
    /usr/local/mysql/bin/mysqladmin -u$user -p$userPWD flush-logs
    #定义增量备份位置
    daily_databakDir=/backup/mysql/daily_backup
    #定义MYSQL数据日志目录
    mysqlDataDir=/usr/local/mysql/var
    #定义增量日志及目录
    eMailFile=$daily_databakDir/email.txt
    #eMail=admin@zxsdw.com
    #定义变量DATE格式为20150127
    DATE=`date +%Y%m%d`
    #定义一个总的logFile日志
    logFile=$daily_databakDir/mysql$DATE.log
    
    
    #美化日志模板
    echo "       " > $eMailFile
    echo "-----------------------" >> $eMailFile
    #时间格式为15-01-27 01:06:17
    echo $(date +"%y-%m-%d %H:%M:%S") >> $eMailFile
    echo "-------------------------" >> $eMailFile
    
    
    #定义删除bin日志的时间范围,格式为20150124010540
    TIME=$(date "-d 3 day ago" +%Y%m%d%H%M%S)
    #定义需要增量备份数据的时间范围,格式为2015-01-26 01:04:11
    StartTime=$(date "-d 1 day ago" +"%Y-%m-%d %H:%M:%S")
    
    ###########开始删除操作美化日志标题##############
    echo "Delete 3 days before the log" >>$eMailFile
    
    #删除三天前的bin文件,及更新index里的索引记录,美化日志标题
    mysql -u$user -p$userPWD -e "purge master logs before ${TIME}" && echo "delete 3 days before log" |tee -a $eMailFile
    
    #查找index索引里的bin 2进制文件并赋值给 i。
    filename=`cat $mysqlDataDir/mysql-bin.index |awk -F "/" '{print $2}'`
    for i in $filename
    do
    #########开始增量备份操作,美化日志标题###########
    echo "$StartTime start backup binlog" >> $eMailFile
    
    #利用mysqlbinlog备份1天前增加的数据,并gzip压缩打包到增量备份目录
    /usr/local/mysql/bin/mysqlbinlog -u$user -p$userPWD -d $database --start-datetime="$StartTime" $mysqlDataDir/$i |gzip >> $daily_databakDir/daily$DATE.sql.gz |tee -a $eMailFile
    
    done
    
    
    #如果以上备份脚本执行成功,接着运行下面的删除脚本
    if [ $? = 0 ]
    then
    # 删除mtime>32的增量日志备份文件
    find $daily_databakDir -name "*.log" -type f -mtime +32 -exec rm {} ; > /dev/null 2>&1
    cd $daily_databakDir
    echo "Daily backup succeed" >> $eMailFile
    else
    echo "Daily backup fail" >> $eMailFile
    #mail -s "MySQL Backup" $eMail < $eMailFile #备份失败之后发送邮件通知
    #fi结束IF判断
    fi
    
    
    #把变量eMailFile的内容替换logFile内容
    cat $eMailFile > $logFile
    
    #如果上面的IF判断失败,再次运行删除mtime>32的增量日志备份文件
    find $daily_databakDir -name "*.log" -type f -mtime +32 -exec rm {} ; > /dev/null 2>&1
    

      

  • 相关阅读:
    如何实现九宫格布局-----源码如下
    查询出的数据记录字段要与实体类中的属性名一致
    2016/12/14---- C3P0
    Spring的数据库操作---- Spring框架对JDBC的整合 ---- 初始化JdbcTemplate对象
    Spring的数据库操作---- Spring框架对JDBC的整合---- 初始化连接池数据源对象
    Spring的数据库操作---- Spring框架对JDBC的整合---- Spring的数据库操作
    Spring的数据库操作---- Spring框架对JDBC的整合---- spring集成jdbc概述
    Spring的AOP机制---- AOP的注解配置---- AOP的注解配置
    Spring的AOP机制---- 切入点表达式---- 切入点表达式
    Spring的AOP机制---- AOP环绕通知---- AOP环绕通知
  • 原文地址:https://www.cnblogs.com/microtiger/p/8005183.html
Copyright © 2011-2022 走看看