首页 | 编程语言 | 网站建设 | 游戏天堂 | 冲浪宝典 | 网络安全 | 操作系统 | 软件时空 | 硬件指南 | 病毒相关 | IT 认证
软讯网络 > 冲浪宝典 > 网络资源 > 一个Mysql自动备份脚本(转)
【标  题】:一个Mysql自动备份脚本(转)
【关键字】:Mysql
【来  源】:http://www.cublog.cn/u/6402/showart.php?id=189011

一个Mysql自动备份脚本(转)

了一个Mysql备份的脚本,大家看看,有什么不妥地方。

这是我写的第一个Shell脚本,大家帮忙看看,

有谁需要的,我可以发给他。

可以将这个脚本放进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="$BackupPath"db$(date +%y%m%d).tgz
DumpFile="$BackupPath"db$(date +%y%m%d)
OldFile="$BackupPath"db$(date +%y%m%d --date='5 days ago').tgz

echo "-------------------------------------------" >;>; $LogFile
echo $(date +"%y-%m-%d %H:%M:%S") >;>; $LogFile
echo "--------------------------" >;>; $LogFile
#Delete Old File
if [ -f $OldFile ]
then
   rm -f $OldFile >;>; $LogFile 2>;&1
   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 2>;&1
      echo "[$NewFile]Backup Success!" >;>; $LogFile
      rm -rf $DumpFile
      ;;
   mysqlhotcopy)
      rm -rf $DumpFile
      mkdir $DumpFile
      if [ -z $DBPasswd ]
      then
         mysqlhotcopy -u $DBUser $DBName $DumpFile >;>; $LogFile 2>;&1
      else
         mysqlhotcopy -u $DBUser -p $DBPasswd $DBName $DumpFile >;>;$LogFile 2>;&1
      fi
      tar czvf $NewFile $DumpFile >;>; $LogFile 2>;&1
      echo "[$NewFile]Backup Success!" >;>; $LogFile
      rm -rf $DumpFile
      ;;
   *)
      /etc/init.d/mysqld stop >;/dev/null 2>;&1
      tar czvf $NewFile $DBPath$DBName >;>; $LogFile 2>;&1
      /etc/init.d/mysqld start >;/dev/null 2>;&1
      echo "[$NewFile]Backup Success!" >;>; $LogFile
      ;;
   esac
fi

echo "-------------------------------------------" >;>; $LogFile
MySQL集群配置 (未测试):【上一篇】
双机问题解决过程:【下一篇】
【相关文章】
  • MySQL集群配置 (未测试)
  • 设置MySQL的系统变量以调优性能
  • FreeBSD Vsftp Mysql
  • Linux下建立Mysql镜像数据库(mysql 4.1)
  • MySql篇
  • squid-2.5STABLE13的http代理+mysql认证(mysql_auth-0.8)
  • [原创]Mysql自定义函数
  • [原创]扩展求方差的mysql函数例子
  • MySQL安装和基本使用方法
  • 忘记mysql 密码的取回方法
  • 【随机文章】
  • 禁止在"控制面板"中显示"网络"属性
  • ASP.NET中的状态管理(1)
  • C++ Builder 运行时包
  • Photoshop无痕迹拼接美女图像(1)
  • [课程提纲] 第四章-用例建模
  • Spring就是强,Java同仁必备
  • MAX+Premiere片头教程
  • GRUB配置文件的结构
  • ClearCase Deliver过程解析
  • 探索Heap Corruption
  • 【相关评论】
    没有相关评论
    【发表评论】
    姓名:
    邮件:
    随机码*
    评论*
          
    |  首 页  |  版权声明  |  联系我们   |  网站地图  |
    CopyRight © 2004-2007 软讯网络 All Rigths Reserved.