当前所在位置:珠峰网资料 >> 计算机 >> 计算机等级考试 >> 正文
2015年计算机四级指导:MySQL数据库每天自动备份脚本
发布时间:2010/3/10 17:49:36 来源:城市学习网 编辑:MOON
  之前,有用户向我们提出过疑问:如何才能实现MySQL的自动备份,当时,我们的回复是编一个自动脚本。现在我们把这段代码贴出来,希望对各位有所帮助。可以将这个脚本放进crontab,每天凌晨执行一次 ...
  之前,有用户向我们提出过疑问:如何才能实现MySQL的自动备份,当时,我们的回复是编一个自动脚本。
  现在我们把这段代码贴出来,希望对各位有所帮助。可以将这个脚本放进crontab,每天凌晨执行一次,自动备份。
  这个脚本每天最多只执行一次,而且只保留最近五天的备份在服务器上。
  代码:
  #!/bin/bash
  #This is a ShellScript For Auto DB Backup
  #Powered by aspbiz
  #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
  #Setting End
  NewFile=$BackupPathdb$.tgz
  DumpFile=$BackupPathdb$
  OldFile=$BackupPathdb$.tgz
  echo ------------------------------------------- $LogFile
  echo $ $LogFile
  echo -------------------------- $LogFile
  #Delete Old File
  if [ -f $OldFile ]
  then
  rm -f $OldFile $LogFile 21
  echo [$OldFile]Delete Old File Success! $LogFile
  else
  echo [$OldFile]No Old Backup File! $LogFile
  fi
  if [ -f $NewFile ]
  then
  echo [$NewFile]The Backup File is exists,Can‘t Backup! $LogFile
  else
  case $BackupMethod in
  mysqldump)
  if [ -z $DBPasswd ]
  then
  mysqldump -u $DBUser --opt $DBName $DumpFile
  else
  mysqldump -u $DBUser -p$DBPasswd --opt $DBName $DumpFile
  fi
  tar czvf $NewFile $DumpFile $LogFile 21
  echo [$NewFile]Backup Success! $LogFile
  rm -rf $DumpFile
  ;;
  mysqlhotcopy)
  rm -rf $DumpFile
  mkdir $DumpFile
  if [ -z $DBPasswd ]
  then
  mysqlhotcopy -u $DBUser $DBName $DumpFile $LogFile 21
  else
  mysqlhotcopy -u $DBUser -p $DBPasswd $DBName $DumpFile $LogFile 21
  fi
  tar czvf $NewFile $DumpFile $LogFile 21
  echo [$NewFile]Backup Success! $LogFile
  rm -rf $DumpFile
  ;;
  )
  /etc/init.d/mysqld stop /dev/null 21
  tar czvf $NewFile $DBPath$DBName $LogFile 21
  /etc/init.d/mysqld start /dev/null 21
  echo [$NewFile]Backup Success! $LogFile
  ;;
  esac
  fi
  echo ------------------------------------------- $LogFile
广告合作:400-664-0084 全国热线:400-664-0084
Copyright 2010 - 2017 www.my8848.com 珠峰网 粤ICP备15066211号
珠峰网 版权所有 All Rights Reserved