公司有三台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 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
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。