公司有三台sql server数据库,每天通过sql server计划任务备份数据到本地,再通过本地上传到数据服务器上做保存,如此反复,有时因为工作忙,忘了上传,导致数据被替换而没有备份的现象。

经过对Linux学习,发现这一切都只是小问题,不需要这么麻烦,如是说干就干。

  1. 通过查资料,sql server是可以通过远程方式备份的,如果配置好sql server的远程备份功能,将数据每天备份到指定的数据存储服务器上

  2. 将数据备份服务器从windows 7改装成centos 6.5

  3. 现在问题是sql server每天传过来的数据库文件是相同文件名的,是会将原有备份替换的,这样就保存不了多天的数据了,如是我想利用脚本的方式实现当数据库备份文件传过来后,我就在当前目录创建一个日期文件夹,然后将数据库文件自动移动到该文件夹中,这样下次备份的时候,就不会替换了,如果循环

  4. 为了防止磁盘空间不足,我在脚本中加入find,查找到大于30天的数据就清除,(find ./ -type f -mtime +30 -name "*.bak" | xargs rm -f)只保留30天,因为公司对这数据库不是很严格要求保留多少天,所以我就看磁盘的空间来定

  5. 然后通过df -h查看备份磁盘的空间大小,做一个每天的邮件通过,告诉管理员,当天删除的是哪天的备份,磁盘空间还余多少。

以下是脚本实现:

#!/bin/bash

WEEK=`date +%w`

# Disk size chkeck

echo `df -h | awk '{print $4}'| sed -n '5p'| sed -r 's#(.*)#Waring /Hddf Avail \1 please chkeck Disk#'`>/Shell/backup.log

find /Hddf/database/  -maxdepth 1 -mtime +24 -type d ! -name "zabbix" ! -name "db" ! -name "RTX*" -exec rm -rf {} \; &&\

echo `df -h | awk '{print $4}'| sed -n '5p'| sed -r 's#(.*)#Waring /Hddf Avail \1 please chkeck Disk#'`>>/Shell/backup.log

if [ $? -eq 0 ];then

echo "`date +%y%m%d` 删除成功  `find /Hddf/database/  -maxdepth 1 -mtime +24 -type d ! -name "zabbix" ! -name "db" ! -name "RTX*"`">>/Shell/b

ackup.log

else

echo "`date +%y%m%d` 删除不成功 ">>/Shell/backup.log

fi

# from email admin

mail -s "databackup" zhongliang@hdbattery.cn </Shell/backup.log

if [ $WEEK -ne 0 ];then

if [ ! -d /Hddf/database/`date +%y%m%d` ];then

        mkdir -p /Hddf/database/`date +%y%m%d`

        mv  /Hddf/database/{*.bak,*.BAK}  /Hddf/database/`date +%y%m%d`/

fi

else

        echo "今天是星期日 没有数据备份">> /Shell/mvdata.txt

fi