文档章节

shell 滚动备份

老汉-憨憨
 老汉-憨憨
发布于 2017/09/06 19:30
字数 300
阅读 22
收藏 0
点赞 0
评论 0
#!/bin/sh

if [ $# != 6 ]; 
then
   echo "Usage: $0  <dir> <pre> <rm-day> <tar-day> <app_num> <dir_num>"
   echo "e.g.: $0 /data/invoice flow 7 3 55 1000"
   exit 0
fi


vdir=$1     #/data/invoice
vpre=$2     #flow
vrmday=$3   #7
vtarday=$4  #3
vappnum=$5  #55
vdirnum=$6  #1000

function backup_dir()
{
    local i=0
    if [ ! -d $1 ]; then
        return
    fi
    
    rm_file="$2_"`date -d "$3 days ago" +%Y%m%d`".tar.gz" 
    logfile="$2_"`date -d "$4 days ago" +%Y%m%d`"*.log"
    tarfile="$2_"`date -d "$4 days ago" +%Y%m%d`".tar.gz"

    cd $1
    for i in `seq 1 $vdirnum`
    do
        cd $i
        rm -f ${rm_file}
        tar cvf ${tarfile} ${logfile}
	    rm -f ${logfile}
        cd -
    done
}

function remove_dir()
{
    local i=0
    if [ ! -d $1 ]; then
        return
    fi

    cd $1
    for i in `seq 1 $vdirnum`
    do
        cd $i
            rm -f *.tar.gz
            tarfile="$2_"`date -d "$4 days ago" +%Y%m%d`"*.log" 
            rm -f $tarfile
        cd -
    done
}

#特殊的appid
arr=(18 34 16 41 5 10 36 40 45 55)

#删除指定时间段的数据
rmdate=(14 14 15 3 10 10 10 31 20)

#打包指点时间段的数据
tardate=(7 7 14 3 7 7 7 30 30)

appid=($(seq 1 1 ${vappnum}))
for var in ${arr[*]}
do
    f=$(($var - 1))
    unset appid[$f]
done

#测试
#unset appid
#appid=(1)

for var in ${appid[*]}
do
    cur_dir="$vdir/$var/"
    backup_dir $cur_dir $vpre $vrmday $vtarday
done

len=${#arr[@]}
len=$(( $len - 1 )) # 55特殊处理

i=0
while [ $i -lt $len ]
do
    appid=${arr[$i]}
    cur_dir="$vdir/$appid"
    if [[ "$appid" = "41" || "$appid" = "45" ]];
    then
        remove_dir $cur_dir $vpre ${rmdate[$i]} ${tardate[$i]}
    else
        backup_dir $cur_dir $vpre ${rmdate[$i]} ${tardate[$i]}
    fi
    i=$(( $i + 1 ))
done

 

© 著作权归作者所有

共有 人打赏支持
老汉-憨憨
粉丝 18
博文 322
码字总数 68382
作品 0
深圳
程序员
emacs 在shell编辑缓冲区执行命令

-一次执行一条命令 M! -执行一条shell命令,并把结果放到当前编辑缓冲区 C-u M ! ============================= 下面正式进入shell编辑缓冲区 ============================= -启动shell...

flash_fish ⋅ 2014/12/17 ⋅ 0

一次数据库误update之后的数据恢复

工作需要,要对数据库(mysql)数据进行对比,写完测试脚本。想在表中修改一条数据,然后运行程序看看效果。正确的sql。可是实际情况是没有写where条件,就按下了回车,shell很快返回“**条数...

youthflies ⋅ 2014/08/23 ⋅ 1

MySQL之备份还原,主从复制,主主复制。

数据库作为我们的日常工作中不可缺少的部分,那它内部数据的重要性显而易见,所以数据安全至关重要。确保数据的安全,我们就必须做好数据备份。简单说几个MySQL常用的备份工具以及如何利用这...

chinahaike ⋅ 2014/07/01 ⋅ 0

mysql-zrm增备数据恢复时的注意事项

mysql-zrm --action restore --source=/common/test/20170407091226/--backup-set test --verbose 对于一个数据库的全备、增备恢复当然没有问题了 但是,但是,但是:当备份多个库时有异常情...

insist_way ⋅ 2017/04/15 ⋅ 0

mariadb备份与恢复工具

1.mysqldump: shell> mysqldump [options] db_name [tbl_name ...] #可以备份单个数据库的单个表,不会自动创建数据库,恢复时需要先创建数据库shell> mysqldump [options] --databases db...

love8023icando ⋅ 2015/11/11 ⋅ 0

基于mysqldump备份mysql(MairaDB)

一、简介 mysqldump是mysql用于转存储数据库的实用程序。它主要产生一个SQL脚本,其中包含从头重新创建数据库所必需的命令CREATE TABLE INSERT等 它可以把整个数据库装载到一个单独的文本文件...

nmshuishui ⋅ 2014/04/30 ⋅ 0

Xtrabackup与innobackupex热备份MySQL数据

Xtrabackup与innobackupex热备份MySQL数据 一.Xtrabackup 简介及备份原理说明: Xtrabackup是由percona开发的一个开源软件,能够非常快速地备份与恢复mysql数据库,且支持在线热备份(备份时...

烟头网管 ⋅ 2015/12/02 ⋅ 0

基于mysqldump及lvm snapshot备份mysql数据库

mysql备份类型主要有一下三种: 热备份:备份时服务照常在线,读写都不受影响; 温备份:备份时仅可进行读操作,需要申请锁; 冷备份:也叫离线备份,读写操作必须中止; 不同的存储引擎对备...

li13522275125 ⋅ 2014/04/22 ⋅ 0

MySQL 备份与恢复

1.备份与恢复的类型 逻辑备份与物理备份 线上备份与线下备份 本地备份与远程备份:mysqldump,mysqlhotcopy(第三方PERL程序),select ... into outfile 快照备份(mysql自身不支持),可使用第三方...

VictorLi ⋅ 2010/11/28 ⋅ 3

Mysql备份和恢复策略

在数据库表丢失或损坏的情况下,备份你的数据库是很重要的。如果发生系统崩溃,你肯定想能够将你的表尽可能丢失最少的数据恢复到崩溃发生时的状态。本文主要对MyISAM表做备份恢复。 备份策略...

学习环境 ⋅ 2015/12/15 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

Greys Java在线问题诊断工具

Greys是一个JVM进程执行过程中的异常诊断工具。 在不中断程序执行的情况下轻松完成JVM相关问题排查工作 目标群体 有时候突然一个问题反馈上来,需要入参才能完成定位,但恰恰没有任何日志。回...

素雷 ⋅ 28分钟前 ⋅ 0

git从远程仓库拉取代码的常用指令

一种(比较麻烦的)拉代码的方法 git clone //克隆代码库,与远程代码库的主干建立连接,如果主干已经在就不用再clone啦,克隆路径为当前路径下的新创建的文件夹 git checkout -b //本地建立...

Helios51 ⋅ 43分钟前 ⋅ 0

005. 深入JVM学习—Java堆内存参数调整

1. JVM整体内存调整图解(调优关键) 实际上每一块子内存区域都会存在一部分可变伸缩区域,其基本流程:如果内存空间不足,则在可变的范围之内扩大内存空间,当一段时间之后,内存空间不紧张...

影狼 ⋅ 48分钟前 ⋅ 0

内存障碍: 软件黑客的硬件视图

此文为笔者近日有幸看到的一则关于计算机底层内存障碍的学术论文,并翻译(机译)而来[自认为翻译的还行],若读者想要英文原版的论文话,给我留言,我发给你。 内存障碍: 软件黑客的硬件视图...

Romane ⋅ 今天 ⋅ 0

SpringCloud 微服务 (七) 服务通信 Feign

壹 继续第(六)篇RestTemplate篇 做到现在,本机上已经有注册中心: eureka, 服务:client、order、product 继续在order中实现通信向product服务,使用Feign方式 下面记录学习和遇到的问题 贰 or...

___大侠 ⋅ 今天 ⋅ 0

gitee、github上issue标签方案

目录 [TOC] issue生命周期 st=>start: 开始e=>end: 结束op0=>operation: 新建issueop1=>operation: 评审issueop2=>operation: 任务负责人执行任务cond1=>condition: 是否通过?op3=>o......

lovewinner ⋅ 今天 ⋅ 0

浅谈mysql的索引设计原则以及常见索引的区别

索引定义:是一个单独的,存储在磁盘上的数据库结构,其包含着对数据表里所有记录的引用指针. 数据库索引的设计原则: 为了使索引的使用效率更高,在创建索引时,必须考虑在哪些字段上创建索...

屌丝男神 ⋅ 今天 ⋅ 0

String,StringBuilder,StringBuffer三者的区别

这三个类之间的区别主要是在两个方面,即运行速度和线程安全这两方面。 首先说运行速度,或者说是, 1.执行速度 在这方面运行速度快慢为:StringBuilder(线程不安全,可变) > StringBuffer...

时刻在奔跑 ⋅ 今天 ⋅ 0

java以太坊开发 - web3j使用钱包进行转账

首先载入钱包,然后利用账户凭证操作受控交易Transfer进行转账: Web3j web3 = Web3j.build(new HttpService()); // defaults to http://localhost:8545/Credentials credentials = Wallet......

以太坊教程 ⋅ 今天 ⋅ 0

Oracle全文检索配置与实践

Oracle全文检索配置与实践

微小宝 ⋅ 今天 ⋅ 0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部