jiang1799 发表于 2018-8-26 13:35:17

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

  公司有三台sql server数据库,每天通过sql server计划任务备份数据到本地,再通过本地上传到数据服务器上做保存,如此反复,有时因为工作忙,忘了上传,导致数据被替换而没有备份的现象。
  经过对Linux学习,发现这一切都只是小问题,不需要这么麻烦,如是说干就干。

[*]  通过查资料,sql server是可以通过远程方式备份的,如果配置好sql server的远程备份功能,将数据每天备份到指定的数据存储服务器上
[*]  将数据备份服务器从windows 7改装成centos 6.5
[*]  现在问题是sql server每天传过来的数据库文件是相同文件名的,是会将原有备份替换的,这样就保存不了多天的数据了,如是我想利用脚本的方式实现当数据库备份文件传过来后,我就在当前目录创建一个日期文件夹,然后将数据库文件自动移动到该文件夹中,这样下次备份的时候,就不会替换了,如果循环
[*]  为了防止磁盘空间不足,我在脚本中加入find,查找到大于30天的数据就清除,(find ./ -type f -mtime +30 -name "*.bak" | xargs rm -f)只保留30天,因为公司对这数据库不是很严格要求保留多少天,所以我就看磁盘的空间来定
[*]  然后通过df -h查看备份磁盘的空间大小,做一个每天的邮件通过,告诉管理员,当天删除的是哪天的备份,磁盘空间还余多少。
  以下是脚本实现:
  #!/bin/bash
  WEEK=`date +%w`

  # Disk>  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/mvdata.txt
  fi

页: [1]
查看完整版本: 小企业sql server数据备份shell脚本解决方案