Linux下系统的定时及延时任务

一、系统的延时

  •  是临时的。对系统做的任务指定一个时间点。发起的命令是at

at    时间点(now+1min)      ## 设定任务实行时间

  at>  执行命令                    ## 任务的动作

at><EOT>                 ## 用ctrl+D发起任务

  •  at命令常用参数:

  at   -l    查看列表

   
 

  at   -c  任务号   查看任务内容

   

   at    -r  任务号  取消任务执行

  注意:任务有输出的时候,输出会以邮件的形式发送给at任务的发起者。在超级用户下查看邮件命令:mail(邮件在/var/mail/root下)。

  •  使用:  mail  -u  root      查看root用户的邮件

  按n表示查看第n封的内容

  按q表示退出

>  /var/spool/mail/root    清空邮件  

 

二、设置延时任务的黑白名单

/etc/at.deny    系统中默认存在,在此文件中的用户不能执行at

/etc/at.allow     系统中默认不存在;当存在时,普通用户不能执行at命令,且只有在该文件中用户可以执行

在root用户下设置黑名单:vim  /etc/at.deny    添加 student      ##此时在student用户下,不可以执行延时任务的设定

在root用户下设置白名单:/etc/at.allow (该文件默认是不存在的)若建立出来,则普通用户不能执行at命令;除了超级用户,只有在at.allow里面的用户才能使用at命令。          

注意:白名单出现,黑名单则会失效!

三、系统定时任务设定

  该命令是永久的。

    【1】系统控制crontab的服务

      crond.service  ## 当该服务开启时,控制定时任务生效(不会执行错误时间点的任务)

 

    【2】crontab相关命令

  •   使用命令:  crontab  -e  -u   root 对文件编辑,以下结果表示每分钟执行一次file1的创建 (-e 直接设定 -u  指定发起的用户  无-u默认当前用户)  
    
     
     注意:该文件目录是:/var/spool/cron/,文件名为root(用户发起者是谁,文件名就是谁
  •  使用命令:crontab  -l   -u  root  查看该用户文件内容(与cat  /var/spool/cron/root结果一样)         

 

    
 
  •  使用命令:crontab  -r  -u   root   对该用户的文件内容的删除 
     

    【3】crontab  时间表示方式: 

 

    *   *  *  *  *   rm  -rf     /mnt/*    ## 表示每分钟执行一次

    * /2  *  *  *  *              ## 表示每2分钟执行一次

    * /2  09-17  *  *  *            ##上午九点到下午的五点每两分钟执行一次

    * /2  */2    *  *  *          ## 每个两小时每两分钟

    * /2  09-17  *  *  5             ## 【2】 该【1】条件的基础上加上只在周五做

    * /2  09-17  *  1  5         ## 每周周五和每月一号的早9晚5没两分钟执行一次  

    * /2  09-17  3,5  1  5             ##表示3月和五月每周周五和3.1及5.1的上午9点到下午5点,且每2分钟一次

     注释: man  crontab   命令使用查看      

                  man 5 crontab   查看该文件

  •  根目录下的anacron用来监控并执行漏过的定时任务(crond.service默认是开机自启动)  

  【3】文件的方式设定

  1)交互式:

      vim    /etc/cron.d/filename  ## 文件名自己取

     *   *   *   *     *  username    action

  实例:每分钟使用root用户执行/mnt/test/目录下文件的删除   

     
    注释:打开另一个终端,可以使用watch -n 1 ls /mnt/test/* 命令观察文件的内容

 

    2)非交互式:

     [root@foundation77 cron.d]# touch westos

     [root@foundation77 cron.d]# echo "* * * * * root touch /mnt/test/xniu" >> westos     ## 由于存在特殊字符*,所以要双引号
     [root@foundation77 cron.d]# cat westos
     * * * * * root touch /mnt/test/xniu


   【4】使用crontab命令的执行限定

     /etc/cron.deny     系统中默认存在,在此文件中的用户不能执行crontab

      /etc/cron.allow     系统中默认不存在;当存在时,普通用户不能执行crontab命令,且只有在该文件中用户可以执行

    注意:这两个名单不会影响/etc/cron.d/目录中定时任务的发起及执行 

     示例:

     1)修改/etc/cron.deny 文件,把student添加进去

     2)修改/etc/cron.allow文件为空

     3)使用 vim /etc/cron.b/westos,对内容进行修改

  

   
    4)一分钟后,在/home/student目录下对文件进行查看:

 

     [root@foundation77 cron.d]# ll /home/student/

     total 0
     -rw-r--r--. 1 student student 0 Aug  1 23:58 hello

 

四、临时文件的管理

  【1】临时文件,顾名思义为当一个程序运行时,临时需要的文件。 

   cd    /usr/lib/tmpfiles.d/

   vim   westos.conf

   d  /mnt/westos  777   root   root    8s    ## 各参数分别表示:目录形式   目录名   权限   用户  组用户    清理的时长

 

   systemd-tmpfiles   --create    /usr/lib/tmpfiles.d/*    ## 建立westos.conf里面的文件

   systemd-tmpfiles  --clean    /usr/lib/temfiles.d/*    ## 在时长到达后,执行该命令会对临时文件进行删除

    【2】示例:

      [root@foundation77 cron.d]# cd /usr/lib/tmpfiles.d/

      [root@foundation77 tmpfiles.d]# vim xniu.conf
     
      [root@foundation77 tmpfiles.d]# systemd-tmpfiles --create /usr/lib/tmpfiles.d/*
      [root@foundation77 tmpfiles.d]# ls /mnt/
      create_all.sh  software  test1     vm_kuaizhao.sh
      creat_vm.sh    test      test.xml  vm_reset.sh
      [root@foundation77 tmpfiles.d]# touch /mnt/test1/file{1,6}
      [root@foundation77 tmpfiles.d]# ls /mnt/test1/
      file1  file6
      [root@foundation77 tmpfiles.d]# systemd-tmpfiles --clean /usr/lib/tmpfiles.d/*     ##执行该命令的时候,时间要超过8s
      [root@foundation77 tmpfiles.d]# ls /mnt/test1/
     

 

posted @ 2018-08-02 00:26  UTHN_B  阅读(1666)  评论(0编辑  收藏  举报