查看定时任务

crontab -l

  • 注册定时任务

crontab -e
然后就像 vim 一样编辑自己的定时任务。
如:
 * * * * * . /home/hadoop/timer/check_job.sh >> /home/hadoop/timer/logs/check_job.log

  • 定时任务解析
  1. *和*之间的空格,是必须的
  2. *分别代表:分,时,日,月,周
    • 1. 分 的取值范围为:0-59
    • 2. 时 的取值范围为:0-23
    • 3. 日 的取值范围为:1-31
    • 4. 月 的取值范围为:1-12
    • 5. 周 的取值范围为:0-7 
  3. *后面是需要执行的命令
  4. "." 代表是shell 命令,也可以使用 sh
  5. ">>" 前面的是需要定时调用的shell,后面是 需要输出的 log 文件的位置​
  • 实例

1.  * * * * * 代表每分钟执行一次,也可以写成 */1 * * * *,/1代表一分钟执行一次 
2.  30 */1 * * * 代表每小时的 30 分执行一次

以下是对文件的操作

  • 根据文件名称取得最大日期对文件

    • 文件名称的格式为:filter_cache_20171101.se
    max_date=0
    # get the latest file and copy to hdfs
    cd /home/hadoop/.../checkpoint/filter
    for dir in $(ls -l ./ | awk '/^d/{print $NF}')
    do
    if [[ -d $dir && $dir == *\_* ]]; then
    f_d=$(echo $dir | cut -d \_ -f 3 | cut -d \. -f 1)
    if [[ $max_date < $f_d ]]; then
    max_date=$f_d
    max_filter=$dir
    fi
    fi
    done
    echo " max date is : "$max_date
    echo " max filter is : "$max_filter

  • 复制最近日期对文件到hdfs

    • 如果文件存在,提示已经存在
    hadoop fs -test -e /data/.../bloom_filters/$max_filter
    if [[ $? == 0 ]]; then
    echo " filter is already exist : "$max_filterF
    else
    echo " start hdfs copy "
    hadoop fs -put $max_filter /data/.../bloom_filters
    fi

  • 设定需要删除过期文件的指定时间

    remove_week=$(date -d "$max_date 7 days ago" +%Y%m%d)
    echo " 删除本地序列化文件的日期界限:"$remove_week
    remove_date=$(date -d "$max_date 30 days ago" +%Y%m%d)
    echo " 删除文件 和 Hadoop filter 的日期界限:"$remove_date

  • 删除指定日期30天以外的本地文件,并且删除小于指定日期7天以外的指定文件夹的文件

    for r_dir in $(ls -l ./ | awk '/^d/{print $NF}')
    do
    if [[ -d $r_dir && $r_dir == *\_* ]]; then
    r_d=$(echo $r_dir | cut -d \_ -f 3 | cut -d \. -f 1)
    if [[ $r_d < $remove_date ]]; then
    echo " remove filter_dir is: "$r_dir
    rm -r $r_dir
    elif [[ $r_d < $remove_week ]]; then
    echo " remove filter is: "$r_dir
    rm -r $r_dir/*.FILTER.SER
    fi
    fi
    done

  • 删除hdfs上指定日期30以外的文件

Linux笔记:定时任务和文件操作的更多相关文章

  1. Windows phone 8 学习笔记(2) 数据文件操作

    原文:Windows phone 8 学习笔记(2) 数据文件操作 Windows phone 8 应用用于数据文件存储访问的位置仅仅限于安装文件夹.本地文件夹(独立存储空间).媒体库和SD卡四个地方 ...

  2. Linux C高级编程——文件操作之系统调用

    Linux C高级编程文件操作之系统调用 宗旨:技术的学习是有限的,分享的精神是无限的.           库函数是一些完毕特定功能的函数.一般由某个标准组织制作公布,并形成一定的标准.使用库函数编 ...

  3. Python学习Day2笔记(集合和文件操作)

    1.集合的使用 列表是有序的可包含重复内容的 集合是无序的不可包含重复内容的 1) 集合关系测试 #列表去重list_1=[1,4,5,6,7,8,9,7,5,4,23,2] #有重复数据 list_ ...

  4. Windows phone 8 学习笔记(2) 数据文件操作(转)

    Windows phone 8 应用用于数据文件存储访问的位置仅仅限于安装文件夹.本地文件夹(独立存储空间).媒体库和SD卡四个地方.本节主要讲解它们的用法以及相关限制性.另外包括本地数据库的使用方式 ...

  5. Linux常见系统命令与文件操作

    一.Linux常见文件操作 (1)cd /: 在Linux 系统中斜杠“/”表示的是根目录. cd / ,即进入根目录. (2)cd ~命令是,进入用户在该系统的home目录,例如xz用户,则进入/r ...

  6. Python学习笔记八:文件操作(续),文件编码与解码,函数,递归,函数式编程介绍,高阶函数

    文件操作(续) 获得文件句柄位置,f.tell(),从0开始,按字符数计数 f.read(5),读取5个字符 返回文件句柄到某位置,f.seek(0) 文件在编辑过程中改变编码,f.detech() ...

  7. linux常用命令之------文件操作、文件查看、权限、打包压缩

    1.一般公司把linux作为自己的应用服务器,将应用和服务器部署在上面 2.测试一般用来打包.压缩.查日志,写一个简单的shell 获得linux服务器的方式 a:网上租一台云服务器 b:安装vmwa ...

  8. 廖雪峰js教程笔记14 file文件操作

    在HTML表单中,可以上传文件的唯一控件就是<input type="file">. 注意:当一个表单包含<input type="file" ...

  9. Python复习笔记-字典和文件操作

    抽时间回顾2年前自己做过的python工具,突然感觉不像自己写的,看来好久没用过python的字典和文件操作了,查询资料和网页,整理如下: 一.字典 键值对的集合(map) 字典是以大括号“{}”包围 ...

  10. python学习笔记(十)、文件操作

    在前面我们了解到了没得模块,其中有一个模块为fileinput,为文件操作模块,不知道小伙伴们是否还记得? 1 打开文件 要打开文件,可以使用fileinput中的fileinput.input函数进 ...

随机推荐

  1. BZOJ 1396||2865 识别子串

    这个不是题解,看不懂的,别看了 明明应该是会的,怎么还是写了6个小时呢... 把后缀数组.height数组.排名数组求出来,那么对于原串s的任意子串[x,y](表示第x个到第y个字符组成的子串,字符从 ...

  2. 题解报告:hdu 1576 A/B(exgcd、乘法逆元+整数快速幂)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1576 Problem Description 要求(A/B)%9973,但由于A很大,我们只给出n(n ...

  3. CentOS 6.5使用:[3]使用xftp传递文件

    先检查CentOS系统是否安装了FTP服务 [root@centos ~]# rpm -qa | grep vsftpd 如果有内容输出,那么恭喜你,你的系统已经安装了ftp服务   如果没有那么按照 ...

  4. 417 Pacific Atlantic Water Flow 太平洋大西洋水流

    详见:https://leetcode.com/problems/pacific-atlantic-water-flow/description/ C++: class Solution { publ ...

  5. Webform 三级联动例子

    首先分别做三个下拉列表 <body> <form id="form1" runat="server"> <asp:DropDown ...

  6. AJPFX总结JAVA基本数据类型

    1:关键字(掌握)        (1)被Java语言赋予特定含义的单词        (2)特点:                全部小写.        (3)注意事项:              ...

  7. LoadRunner 11中Record无法自动生成脚本——解决办法

    [问题描述] 安装loadRunner 11, 使用IE为默认浏览器,打开一个页面进行脚本录制:录制完成后,无法生成脚本. [问题现象] 控制台输出如下: ****** Start Log Messa ...

  8. R in action读书笔记(15)第十一章 中级绘图 之二 折线图 相关图 马赛克图

    第十一章 中级绘图 本节用到的函数有: plot legend corrgram mosaic 11.2折线图 如果将散点图上的点从左往右连接起来,那么就会得到一个折线图. 创建散点图和折线图: &g ...

  9. Quartz2D知识点聚合案例

    Quartz2D知识点聚合 基本 //画图片 UIImage *image = [UIImage imageNamed:@"阿狸头像"]; [image drawInRect:re ...

  10. github——团队合作