数据库mysql自动备份小策略

    作者:课课家教育更新于: 2016-03-14 18:16:02

      备份是数据库的一大重点,MySQL数据库是大家普遍喜爱的软件,那么恩关于里面的数据自动备份是相当重要的,涉及到我们如何在保护数据。

    数据库mysql自动备份小策略_数据库备份_mysql备份脚本_课课家

      Mysql数据库的备份是非常重要的工作之一,通过MySQL数据库的数据备份就能够实现MySQL数据库中数据的绝对安全,MySQL数据库中的数据不会因为什么小故障而丢失,自动备份则是更为方便的一种备份方式,下文中将给出详细的解析。

      MySql自动备份是非常关键的,特别是对于DBA来说。这里主要用代码来说明这个问题,希望对各位有所帮助。可以将这个脚本放进crontab,每天凌晨执行一次,自动备份。

      这个脚本每天最多只执行一次,而且只保留最近五天的备份在服务器上。

      代码:

      #!/bin/bash

      #ThisisaShellScriptForAutoDBBackup

      #Poweredbyaspbiz

      #2004-09

      #Setting

      #设置数据库名,数据库登录名,密码,备份路径,日志路径,数据文件位置,以及备份方式

      #默认情况下备份方式是tar,还可以是mysqldump,mysqldotcopy

      #默认情况下,用root(空)登录mysql数据库,备份至/root/dbxxxxx.tgz

      DBName=mysql

      DBUser=root

      DBPasswd=

      BackupPath=/root/

      LogFile=/root/db.log

      DBPath=/var/lib/mysql/

      #BackupMethod=mysqldump

      #BackupMethod=mysqlhotcopy

      #BackupMethod=tar

      #SettingEnd

      NewFile="$BackupPath"db$(date+%y%m%d).tgz

      DumpFile="$BackupPath"db$(date+%y%m%d)

      OldFile="$BackupPath"db$(date+%y%m%d--date='5daysago').tgz

      echo"-------------------------------------------">>$LogFile

      echo$(date+"%y-%m-%d%H:%M:%S")>>$LogFile

      echo"--------------------------">>$LogFile

      #DeleteOldFile

      if[-f$OldFile]

      then

      rm-f$OldFile>>$LogFile2>&1

      echo"[$OldFile]DeleteOldFileSuccess!">>$LogFile

      else

      echo"[$OldFile]NoOldBackupFile!">>$LogFile

      fi

      if[-f$NewFile]

      then

      echo"[$NewFile]TheBackupFileisexists,Can'tBackup!">>$LogFile

      else

      case$BackupMethodin

      mysqldump)

      if[-z$DBPasswd]

      then

      mysqldump-u$DBUser--opt$DBName>$DumpFile

      else

      mysqldump-u$DBUser-p$DBPasswd--opt$DBName>$DumpFile

      fi

      tarczvf$NewFile$DumpFile>>$LogFile2>&1

      echo"[$NewFile]BackuPSuccess!">>$LogFile

      rm-rf$DumpFile

      ;;

      mysqlhotcopy)

      rm-rf$DumpFile

      mkdir$DumpFile

      if[-z$DBPasswd]

      then

      mysqlhotcopy-u$DBUser$DBName$DumpFile>>$LogFile2>&1

      else

      mysqlhotcopy-u$DBUser-p$DBPasswd$DBName$DumpFile>>$LogFile2>&1

      fi

      tarczvf$NewFile$DumpFile>>$LogFile2>&1

      echo"[$NewFile]BackupSuccess!">>$LogFile

      rm-rf$DumpFile

      ;;

      *)

      /etc/init.d/mysqldstop>/dev/null2>&1

      tarczvf$NewFile$DBPath$DBName>>$LogFile2>&1

      /etc/init.d/mysqldstart>/dev/null2>&1

      echo"[$NewFile]BackupSuccess!">>$LogFile

      ;;

      esac

      fi

      echo"-------------------------------------------">>$LogFile

      关于MySQL数据库的自动备份就为大家介绍到这里,大家按照上文中讲解的步骤方法去进行MySQL数据库的自动备份工作,相信您一定可以很好的完成MySQL数据库的自动备份工作。

课课家教育

未登录