现在的位置: 首页 > 数据库 > 正文

如何实现MySQL的自动备份

2020年05月06日 数据库 ⁄ 共 2201字 ⁄ 字号 评论关闭

  MySQL数据库的备份是非常重要的工作之一,通过MySQL数据库的数据备份就能够实现MySQL数据库中数据的绝对安全,MySQL数据库中的数据不会因为什么小故障而丢失,自动备份则是更为方便的一种备份方式。下面学步园小编来讲解下如何实现MySQL的自动备份?

  如何实现MySQL的自动备份

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

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

  代码:

  #!/bin/bash

  #ThisisaShellScriptForAutoDBBackup

  #Poweredbyaspbiz

  #2004-09

  #Setting

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

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

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

  如何实现MySQL的自动备份

  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数据库的自动备份工作。

  以上就是关于“如何实现MySQL的自动备份”的内容,希望对大家有用。更多资讯请关注学步园。学步园,您学习IT技术的优质平台!

抱歉!评论已关闭.