如何设置数据库的定时自动备份

如何设置数据库的定时自动备份,第1张

如何设置SQL Server数据库自动备份

数据对于企业来说很重要,因此我们要经常备份,但是我们不可能每天都去手工去备份,因为这样太麻烦了,因此我们可以通过SQL Server自身的自动备份功能,进行对数据库定时实时自动备份.

工具/原料

SQL Server企业管理器

方法/步骤

依次单击:开始--程序--Microsoft SQL Server--企业管理器--SQL Server组--管理--数据库维护计划

在右侧空白处右键单击,新建维护计划--勾选要备份的数据库--下一步

指定数据库备份计划--调度--单击"更改"--设置备份的时间,备份周期--下一步

每日频率即是每天什么时间开始进行备份

发生频率即是执行的周期

指定备份磁盘目录--修改"使用此目录"的路径作为备份数据库的存放路径.勾选删除早于此时间的文件,我这里选择一周,即是数据库备份文件把一周前的进行删除

给此任务计划填写一个名字:back 2单击"完成",就可以在数据库维护计划中看到刚才新建的计划.

注意事项

一定要开启sql server agent服务

linux系统下使用脚本定时备份数据库,代码如下:

#!/bin/bash  

#Setting  

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

#默认情况下备份方式是mysqldump,还可以是mysqldump,mysqldotcopy,如果注释掉第

#18行,则默认以tag的方式备份

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

DBName=mysql

DBUser=root

DBPasswd=123456

BackupPath=/home/wang/www/backup/mysql/mysqlbackup

LogFile=/home/wang/www/backup/mysql/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 >> $LogFile 2>&1  

      /etc/init.d/mysqld start >/dev/null 2>&1  

      echo "[$NewFile]Backup Success!" >> $LogFile  

        

   esac

fi

echo "-------------------------------------------"

echo

#lftp -f lftp.sh 如果有FTP可同时上传ftp中。

再利用crontab命令生成/var/spool/cron/root 文件:

#crontab –e  

//打开一个编辑窗口,第一行会有内容格式的提示,在此输入命令

//m h  dom mon dow   command 

//具体意义表示:分钟 小时 日期 月份 星期  命令,在某月(mon)的某天(dom)或者星期几(dow)的几点(h,24小时制)几分(m)执行某个命令(command)

//如: 10 02 * * * /home/backup/autobackupmysql.sh  (表示零晨二点十分执行备份脚本)


欢迎分享,转载请注明来源:夏雨云

原文地址:https://www.xiayuyun.com/zonghe/461217.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-06-04
下一篇2023-06-04

发表评论

登录后才能评论

评论列表(0条)

    保存