小企业sqlserver数据备份shell脚本解决方案

公司有三台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

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


当前名称:小企业sqlserver数据备份shell脚本解决方案
链接地址:http://pwwzsj.com/article/piphcs.html