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

实现MySQL的自动备份

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

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


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


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


代码:


#!/bin/bash


#ThisisaShellScriptForAutoDBBackup


 


#Poweredbybiz


 


#2004-09


 


#Setting


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


 


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


 


#默认情况下,用root(空)登录my,备份至/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,CantBackup!">>$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数据库的自动备份工作。


 


 

抱歉!评论已关闭.