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

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了小企业sql server数据备份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" [email protected] </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


本文出自 “钟良的linux技术交流博客” 博客,请务必保留此出处http://zhongliang.blog.51cto.com/4507905/1917249

以上是关于小企业sql server数据备份shell脚本解决方案的主要内容,如果未能解决你的问题,请参考以下文章

数据库备份shell脚本

四行shell脚本实现zabbix_server的高可用

SQL Server自动化运维系列——批量执行SQL脚本(Power Shell)

怎样导出sql server2000的表结构(不含数据)

怎样在PHP里执行SQL脚本

Linux+shell管理员的好帮手--批量解压缩