zoukankan      html  css  js  c++  java
  • mysql增量备份(2/2)

    前言

    这是在百度文库里看到的文章,原名叫做《MYSQL 完全与增量备份及恢复文档 》,是关于完全备份和增量备份以及恢复文档的......

    文档介绍
      本文档采用 mysqldump  对数据库进行备份,mysqldump  是采用 SQL 级别的备份机制,它将数据表导成 SQL 脚本文件,在不同的 MySQL 版本之间升级时相对比较合适,这也是最常用的备份方法,mysqldump  比直接拷贝要慢些。
      本文描述 Mysql 数据库的自动备份,包括完全备份和增量备份。其中,完全备份每周六执行一次,系统自动保存最近一个月的备份文件,增量备份每天都会执行,系统自动保存最近 35 天的备份文件。 

    备份策略布置
    (1). 创建备份目录与文件

    Shell> mkdir /srv/bakmysql 
    Shell> mkdir /srv/bakmysql/daily 
    Shell> touch /srv/bakmysql/mysqlbak.log 
    Shell>

    (2). 启用二进制日志
    采用  binlog  的方法相对来说更灵活,省心省力,而且还可以支持增量备份。 
    启用  binlog  时必须要重启  mysqld。首先,关闭  mysqld,打开  /etc/my.cnf,加入以下
    几行: 

    [mysqld] 
    log‐bin

    然后启动 mysqld  就可以了。

    运行过程中会产生 HOSTNAME‐bin.000001  以及 HOSTNAME‐bin.index,前面的文件是 mysqld  记录所有对数据的更新操作后面的文件则是
    所有 binlog 的索引,都不能轻易删除。关于 binlog 的更详细信息请查看手册。 

    (3). 设置 crontab 任务,每天执行备份脚本

    shell> vi /etc/crontab

    添加以下: 

    #每个星期六凌晨 1:00 执行完全备份脚本   
    0 1 * * 6 root /usr/sbin/mysqlfullbak 
    #每天凌晨 6:00 做增量备份 
    0 6 * * *root /usr/sbin/mysqldailybak 

     (4). 使用 SSH 将 mysqldailybak mysqlfullbak rmbackup 三个文本内容放到系统/usr/sbin
    目录下相应的文件中,并且添加可执行权限,如:chmod +x rmbackup 

    脚本内容

    完全备份脚本:

    #!/bin/bash 
    # Name:mysqlfullbak 
    # This is mysql mysqlfullbak scripts 
    # By song 
    # Last Modify:20110223 
     
    #定义脚本存放路径 
    scriptsDir=/usr/sbin 
    #定义用户名及密码 
    user=root 
    userPWD=123456789 
    #定义要备份的数据库 
    database=castor 
    #定义完全备份文件存放路径 
    bakDir=/srv/bakmysql 
     
    eMailFile=$bakDir/email.txt 
    eMail=sdesong@163.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 
    #GZDumpFile=$DATE.sql.tgz 
    mysqldump ‐‐flush‐logs ‐u$user ‐p$userPWD ‐‐quick $database >$DumpFile 
    echo "Dump Done" >> $LogFile 
    #tar cvzf $GZDumpFile $DumpFile >> $LogFile 2 >2&1 
    #echo "[$GZDumpFile]Backup Success!" >> $LogFile 
    echo    "[$DumpFile]Backup Success!" >> $LogFile 
     
    #Delete old backup files(mtime>2) 
    $scriptsDir/rmbackup 
     
    #Delete previous daily backup files:完整备份后,删除增量备份的文件,只保留最近 35 天的增量备份文件 
    daily_databakDir=$bakDir/daily 
    cd $bakDir/daily 
    find $daily_databakDir ‐name "daily*" ‐type f ‐mtime +35 ‐exec rm {} ; > /dev/null 2>&1 
     
    #发送邮件通知 
    #cat $eMailFile | mail ‐s "MySQL Backup" $eMail 

    增量备份脚本:

    #!/bin/bash 
    # Name:mysqldailybak 
    # This ia mysql mysqldailybak scripts 
    # By songdesong 
    # Last modify:20110223 
    #定义用户名及密码 
    user=root 
    userPWD=123456789 
    #定义数据库 
    database=castor 
     
    /usr/bin/mysqladmin ‐u$user ‐p$userPWD flush‐logs 
    daily_databakDir=/srv/bakmysql/daily 
    #定义 MYSQL 数据目录 
    mysqlDataDir=/srv/mysql/ 
     
    eMailFile=$daily_databakDir/email.txt 
    eMail=sdesong@163.com 
     
    DATE=`date +%Y%m%d` 
    logFile=$daily_databakDir/mysql$DATE.log 
    echo "              " > $eMailFile 
    echo "‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐" >> $eMailFile   
    echo $(date +"%y‐%m‐%d %H:%M:%S") >> $eMailFile 
    echo "‐‐‐‐‐‐‐ 
     
    ‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐‐" >> $eMailFile 
    TIME=$(date "‐d 10 day ago" +%Y%m%d%H%M%S) 
    StartTime=$(date "‐d 1 day ago" +"%Y‐%m‐%d %H:%M:%S") 
    echo “Delete 10 days before the log” >>$eMailFile 
    mysql  ‐u$user  ‐p$userPWD  ‐e  "purge  master  logs  before  ${TIME}"  &&  echo  "delete  10  days 
    before log" |tee ‐a $eMailFile #删除 10 天前的 2 进制文件 
     
    filename=`cat $mysqlDataDir/mysqld‐bin.index |awk ‐F "/" '{print $2}'` # 2 进制文件 
    for i in $filename 
    do 
    echo "$StartTime start backup binlog" >> $eMailFile 
    mysqlbinlog       ‐u$user       ‐p$userPWD       ‐d       $database       ‐‐start‐datetime="$StartTime" 
    $mysqlDataDir/$i >> $daily_databakDir/daily$DATE.sql |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 
    #tar ‐cvzf $daily_databakDir/$database$DATE.tar.gz daily$DATE.sql >>/dev/null 2&1 
    #scp  至另一台服务器 
    echo "Daily backup succeed" >> $eMailFile 
    else 
    echo "Daily backup fail" >> $eMailFile 
    mail ‐s "MySQL Backup" $eMail < $eMailFile #备份失败之后发送邮件通知 
    fi 
    cat $eMailFile > $logFile 
     
     
    #  删除 mtime>32 的增量日志备份文件 
    find $daily_databakDir ‐name "*.log" ‐type f ‐mtime +32 ‐exec rm {} ; > /dev/null 2>&1 

    删除完全备份文件脚本:

    #!/bin/sh 
    # Name:rmBackup 
    # PS:Delete old Backup. 
    # By:song 
    # Last Modify:20110217 
    # 
    #  定义备份目录 
    dataBackupDir=/srv/bakmysql 
    #  删除 mtime>32 的日志备份文件 
    find $dataBackupDir ‐name "*.sql" ‐type f ‐mtime +32 ‐exec rm {} ; > /dev/null 2>&1 

    数据库恢复:
    完全备份文件的恢复 
    完全备份文件的格式为:20110301.sql 
    登录 MYSQL(mysql –uroot –proot) 
    use castor; 
    source    /home/20110301.sql 
    增量备份文件的恢复 
    增量备份文件的格式为:daily20110302.sql 
    use castor; 
    source /home/ daily20110302.sql 

  • 相关阅读:
    linux 删除已输入的命令行
    LAMP编译参数查看
    mysql忘记密码的重置方法
    cmd大全_练习
    Parallel WebDriver executions using TestNG
    Internet Explorer for Mac the Easy Way: Run IE 7, IE8, & IE9 Free in a Virtual Machine
    linux delete files older than 3 days
    5 commands to check memory usage on Linux
    Base64 Encoding / Decoding in Node.js
    10 Useful du (Disk Usage) Commands to Find Disk Usage of Files and Directories
  • 原文地址:https://www.cnblogs.com/tv151579/p/3387182.html
Copyright © 2011-2022 走看看