Linux之任务计划at(三)

提示:文章的撰写主要以原理为主,辅以相应的实操!

=============分割线===========================

说明:文章的撰写结合自己的实践、鸟哥私房菜(第三四版)、网上优秀的博客(以相应的链接来引用)

==============开始===============================

需求:22:30提醒我去关机(休息)!

(一)基础

        at命令(概念):用于指定一个定时任务(干什么),在某个特定的时间节点(什么时间执行)执行一次(执行的频率)

        at命令(功能):也可以用于删除、列出已经设置好的定时任务;与at命令相关的命令(别名)有atq,atrm,batch命令。

        at和batch特点:均是从标准输入中(键盘-->默认)指定的文件中(自定义)读取相关的命令,并在指定的时间运行对应的命令,其运行过程中使用的shell为/bin/sh。

        注意:在运行at命令前,需要确保系统启动了atd服务

       实操如下

systemctl status atd      # 查看服务默认的是否开启,确认处于active(running)状态-->绿色

systemctl start atd       # 如果服务未开启,请开启atd服务--->atd守护进程(dameon)

(二)与定时任务at相应的文件

   (1) /var/spool/at/:用户存储设置好的at任务的目录,可进入该目录删除相应的at任务(底层)!
   (2) /etc/at.allow:记录着允许使用at命令的用户,只有在这个目录里的用户才能使用at!
   (3) /etc/at.deny:记录着用户的黑名单,在里面的用户不允许使用at命令!

注意1:at.allow文件的优先级大于at.deny文件!

注意2:记录用户黑白名单的格式是每行一个用户名单,以空格分割!

默认:系统默认会提供一个空的/etc/at.deny文件,假设所有用户都可以使用at命令。

(三)at参数的说明(功能出发)

    -m 当指定的任务被完成之后,将给用户发送邮件(email),即使没有标准输出
    -l 显示"待执行"任务的列表---->atq的别名
    -d 删除指定(任务编号-->先查询)的"待执行"任务;atrm的别名-->不指定编号(删除当前用户所有的任务)
    -v 显示任务将被执行的"时间"--->验证是否是准时执行!
    -c 打印任务的内容到标准输出---->该任务的"实际"命令内容(底层完成的)!
    -V 显示版本信息(大写)
    -q<列队> 使用指定的列队--->不是太懂
    -f<文件> 从指定文件读入任务(自定义)"而不是"从标准输入读入(默认)
    -t<时间参数> 以时间参数的形式提交要运行的任务--->时间格式稍后补充!

 时间格式的分类

 (1)绝对计时法--->列出常见的四中方式

(1) 明天17点钟---->17:20 tomorrow

    格式:HH:MM --->默认是当天,若超时则明天此时刻执行!
(2) 例如:05:00 2018-12-22 

    格式:HH:MM YYYY-MM-DD 
(3) 某年(默认当前)某月某一天的特殊时刻

    格式:HH:MM[am|pm] [Month-->英文] [Date] 

    例如:04:00pm July 30
 
    说明:以空格作为分割

 (2)相对计时法

例如:从当前时刻起再过五分钟执行相关的命令

案例:now + 5 minutes

语法:HH:MM[am|pm] + number [mimutes|hours|days|weeks]--->注意加s

优点:这对于安排不久就要执行的命令是很有好处的。

(四)测试

相关测试省略。。。

原理:指定好时间来执行任务,at命令会进入一个at shell的环境让用户自定义任务的内容(相当于cat >filename的形式),ctrl+d来终止键盘的标准输入,此时会将任务以文件的形式写入到/var/spool/at/目录中,那么文件名是如何命名的呢

解释(接上):文件名系统自定义的,并且文件一旦执行,该文件就自行删除--->思考文件是如何创建和删除的

 [21:32:52][kiosk@foundation10:/var/spool]$ ls -ld /var/spool/at/

 drwx------. 3 daemon daemon 31 1月  19 21:25 /var/spool/at/

 关键:daemon这个用户!

理解:常规思路行不通;dameon是系统用户(伪用户),为了管理相关服务用的,一般每个服务对应一个,但是不能登入系统,他们的shell都是/sbin/nologin------>后续补充

注意1:任务中的命令最好全路径,因为命令的寻找通过PATH(可能不在此路径)

注意2:任务中的文件名最好全路径,因为at运行时会跑到执行at命令的工作目录

优点:后台执行的能力--->脱机后继续执行(网络断线后)

原因:系统会将该任务独立出当前用户的bash环境,交给系统的atd服务程序来接管!

(二)进阶

非常详细的说明文件

at的后台执行(第二段)

猜你喜欢

转载自blog.csdn.net/wzj_110/article/details/86545705