#!/bin/bash #Function:自动备份给定列表中的目录或文件,并且可以保留N天备份的档案。
#可备份至远程主机指定的目录下,但需本机能免密码登录到远程主机,用到ssh-keygen
#该脚本分为两个文件:执行文件backup.sh和备份项目文件bakfile.lst,两个文件必须位于同一目录下
#Author:JianJie #Date:2016/8/26 #Usage:sudo bash backup.sh & #Version:v2 ###############################################################
logFile=/backup/local/log/`date +"%Y-%m"`.log
#日志文件
logDir=/backup/local/log myDate=`date +"%Y-%m-%d"`
bakFileLst=bakfile.lst
#需要备份的文件或目录放到该文件中 bakDir=/backup/local
#备份至此目录 keepDays=5
#文件保留天数 remoteHost="rhel6.8:rhel7"
#需要备份至远程主机的地址,注意本机需免密码登陆到远程主机,多个主机地址或主机名之间用‘:’分割 remoteHostDir=/backup/$HOSTNAME
#远程主机备份目录 currentDir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
#当前运行脚本所在的目录
###############################################################
#判断日志目录和日志文件是否存在
if [ ! -d $logDir ];then
mkdir -p $logDir
touch $logFile else
if [ ! -e $logFile ];then
touch $logFile
fi
fi
#开始记录日志
echo "Backup start at $(date +"%Y-%m-%d %H:%M:%S")" >> $logFile
echo "--------------------------------------------------------" >> $logFile
echo " " >> $logFile
#判断保存备份文件的文件列表'bakfile.lst'是否存在
if [ ! -e $currentDir/$bakFileLst ];then
echo "Error:Important file [$currentDir/$bakFileLst] has been lost,now creating..." >> $logFile
touch $currentDir/$bakFileLst
echo "The file [$currentDir/$bakFileLst] has been created,but you still need to write data in it!" >> $logFile
echo " " >> $logFile echo "--------------------------------------------------------" >> $logFile
echo "Backup end at $(date +"%Y-%m-%d %H:%M:%S")" >> $logFile
echo " " >> $logFile
exit 3
fi
paths=`cat $currentDir/$bakFileLst`
for path in $paths
do
baseName=`echo "$path" | xargs basename`
oldFile=$bakDir/$baseName.$(date --date="$keepDays days ago" +"%Y-%m-%d").txz
#判断路径中备份的是文件还是目录
#若路径中要备份的是文件,则先进入指定路径中的上一级
if [ -f "$path" ];then
#进入指定路径中的上一级目录
cd `echo "$path" | cut -d "/" -f 1-$(echo "$path"|gawk -F"/" '{print NF-1}')`
#若要备份的文件已经存在,则不再重复备份
if [ -f $bakDir/$baseName.$myDate.txz ];then
echo "Backup file [$bakDir/$baseName.$myDate.txz] already exists!" >> $logFile
else
cp -RHpf $baseName $bakDir
cd $bakDir
#备份档案格式为.tar.xz,可根据需要调整,如.tar.gz或者.tar.bz2
tar -cJf $baseName.$myDate.txz $baseName
#将备份后的文件通过scp备份到远程主机
for host in $(echo "$remoteHost" | sed 's/:/ /g')
do
scp -o ConnectTimeout=10 $baseName.$myDate.txz $host:$remoteHostDir >>$logFile 2>/dev/null && \
echo "Successful backup [$path] to the remote host:[$host:$remoteHostDir]" >>$logFile || \
echo "Backup [$path] to the remote host:[$host:$remoteHostDir] failed,please check it" >>$logFile
done
#备份完成,删除拷贝过来的源文件
rm -rf $baseName
echo "Backup [$path] done into [$bakDir] successfuly!" >> $logFile
#若存在N天前旧文件,则删除它
if [ -f $oldFile ];then
rm -rf $oldFile
echo "[$oldFile],delete old file successfuly!" >> $logFile
fi
fi
#路径中备份的是目录
elif [ -d "$path" ];then
#先判断要备份的文件是否已经存在,若存在则不再重复备份
if [ -f $bakDir/$baseName.$myDate.txz ];then
echo "Backup file [$bakDir/$baseName.$myDate.txz] already exists!" >> $logFile
else
cd $path
cd ..
cp -RHpf $baseName $bakDir
cd $bakDir
tar -cJf $baseName.$myDate.txz $baseName
#将备份后的文件通过scp备份到远程主机
for host in $(echo "$remoteHost" | sed 's/:/ /g')
do
scp -o ConnectTimeout=10 $baseName.$myDate.txz $host:$remoteHostDir >>$logFile 2>/dev/null && \
echo "Successful backup [$path] to the remote host:[$host:$remoteHostDir]" >>$logFile || \
echo "Backup [$path] to the remote host:[$host:$remoteHostDir] failed,please check it" >>$logFile
done
#备份完成,删除拷贝过来的源文件
rm -rf $baseName
echo "Backup [$path] done into [$bakDir] successfuly!" >> $logFile
#若存在N天前旧文件,则删除它
if [ -f $oldFile ];then
rm -rf $oldFile
echo "[$oldFile],delete old file successfuly!" >> $logFile
fi
fi
else
echo "Wrong path or file:[$path],please check it" >>$logFile fi done echo " " >> $logFile echo "-------------------------------------------" >> $logFile
echo "Backup end at $(date +"%Y-%m-%d %H:%M:%S")" >> $logFile
echo " " >> $logFile
exit 0
- shell脚本备份日志
#!/bin/sh # back tomcat catalina.out cd /home/log_bak #the file DATE=`date '+%Y%m%d-%H%M'` ARCHIVE=$ ...
- shell脚本备份日志文件
crontab -e crontab -l service crond restart 55 7 * * * /data/app/autoprice7/resin-pro-3.1.15/log_old ...
- centos6.5环境通过shell脚本备份php的web及mysql数据库并做远程备份容灾
centos6.5环境通过shell脚本备份php的web及mysql数据库并做远程备份容灾 系统:centos6.5 1.创建脚本目录 mkdir -p /usr/local/sh/ 创建备份web ...
- shell脚本备份nginx日志
vim /data/runlog.sh #编辑一个 shell 脚本 #!/bin/bash LOGP ...
- 【shell脚本】定时备份日志===logBackup.sh
定时备份日志 设置执行权限 [root@VM_0_10_centos shellScript]# chmod a+x logBackup,sh 脚本内容 [root@VM_0_10_centos sh ...
- linux实现自动远程备份(scp+ssh)
刚上线的服务器需要备份日志,要备份到另一台服务器上去,为了减少工作量,采用linux的定时任务去自动执行.因服务器都是linux的,因此采用linux的远程复制scp命令.但这里涉及到一个问题,就是s ...
- sql server 远程备份 bak 删除
前言: 管理一个公司的一个服务器,最近有一些维护SQLserver数据库活弄,写下防止忘了. 因为公司采用SQL\Redis\MongoDB共用,SQL用来存储基础的结构\权限\等一些杂七杂八的东西. ...
- Linux下使用crontab定时备份日志
上周学习了Linux,其中有使用crontab定时备份日志的内容,现把主要步骤记录如下: 首先需要备份的日志的源目录位于/opt/lampp/logs/access_log 备份到/tmp/logs下 ...
- PL/SQL远程备份和恢复Oracle数据库
(转自:http://blog.csdn.net/huchunfu/article/details/25165901) 在客户端远程备份的文件保存在数据库所在主机上,不会直接拷贝到客户端.—————— ...
随机推荐
- 转 windows 下 Oracle 导出表结构
分析Oracle下导出某用户所有表的方法 可能很多使用Oracle的客户都会遇到想把某用户所有表导出的情况,本文就提供这样一个方法帮你轻松解决这个问题. 首先在sqlplus下以该用户登录到Ora ...
- 遍历Map key-value的两种方法
以前遍历Map key-value比较习惯的方式是先获取Map中的所有key值,然后根据key,依次从Map中去数据,基本方式如下: Map<String,String> testData ...
- Zigbee协议栈OSAL层API函数【转载】
OSAL层提供了很多的API来对整个的协议栈进行管理.主要有下面的几类:信息管理.任务同步.时间管理.中断管理.任务管理.内存管理.电源管理以及非易失存储管理.看到这些管理是不是感 ...
- VS2012添加对DirectX SDK中需要文件的引用
error LNK2019: 无法解析的外部符号 _DirectDrawCreateEx@16,该符号在函数 "int __cdecl DD_Init(int,int,int)" ...
- chrome 开发人员工具
JavaScript Beautifier JavaScript 文件在上线前一般都会压缩下,压缩的 JavaScript 几乎没有可读性,几乎无法设定断点.在 Scripts 面板下面有个 Pret ...
- IMapControl3 Interface(1) Properties属性
IMapControl3 Interface Provides access to members that control the MapControl. Note: the IMapControl ...
- jQuery 查找带有某一属性的元素
$('*[name="username"]') 要在前面加个*表示所有的DOM,如果只是查找带有name属性的DOM的话则是这样的 $('*[name]')//其实, $('[ ...
- Initialization of bean failed; nested exception is java.lang.reflect.MalformedParameterizedTypeExcep
body { font-family: "Microsoft YaHei UI","Microsoft YaHei",SimSun,"Segoe UI ...
- ios中操作技巧
1.配置字段快捷键: @property(nonatimic,copy) NSString *<#param#>; 2.NSNumber 转NSString 最快简单方式: NSNumbe ...
- mac 访问mysql客户端
/usr/local/mysql/bin/mysql -u root -p //mac mysql 管理工具推荐 sequek pro