如何实现MySQL的自动备份
创始人
2024-07-29 04:20:21
0

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

 

相关内容

热门资讯

如何允许远程连接到MySQL数... [[277004]]【51CTO.com快译】默认情况下,MySQL服务器仅侦听来自localhos...
如何利用交换机和端口设置来管理... 在网络管理中,总是有些人让管理员头疼。下面我们就将介绍一下一个网管员利用交换机以及端口设置等来进行D...
施耐德电气数据中心整体解决方案... 近日,全球能效管理专家施耐德电气正式启动大型体验活动“能效中国行——2012卡车巡展”,作为该活动的...
Windows恶意软件20年“... 在Windows的早期年代,病毒游走于系统之间,偶尔删除文件(但被删除的文件几乎都是可恢复的),并弹...
20个非常棒的扁平设计免费资源 Apple设备的平面图标PSD免费平板UI 平板UI套件24平图标Freen平板UI套件PSD径向平...
德国电信门户网站可实时显示全球... 德国电信周三推出一个门户网站,直观地实时提供其安装在全球各地的传感器网络检测到的网络攻击状况。该网站...
为啥国人偏爱 Mybatis,... 关于 SQL 和 ORM 的争论,永远都不会终止,我也一直在思考这个问题。昨天又跟群里的小伙伴进行...
《非诚勿扰》红人闫凤娇被曝厕所... 【51CTO.com 综合消息360安全专家提醒说,“闫凤娇”、“非诚勿扰”已经被黑客盯上成为了“木...