简介
at命令是一次性定时计划任务,at的守护进程atd会以后台模式运行,检查作业队列来运行作业。atd守护进程会检查系统上的一个特殊目录来获取at命令的提交的作业,默认情况下,atd守护进程每60秒检查一次目录,有作业时,会检查作业运行时间,如果时间与当前时间匹配,则运行此作业。
注意:at命令是一次性定时计划任务,执行完一个任务后不再执行此任务了。
命令格式
at [选项] [时间]
Ctrl + D 结束at命令的输入
在使用at命令的时候,一定要保证atd进程的启动。
[root@vms002 /]# ps -ef|grep -v grep|grep atd
rpcuser 1550 1 0 6月10 ? 00:00:00 /usr/sbin/rpc.statd --no-notify
root 1552 1 0 6月10 ? 00:00:00 /usr/sbin/atd -f
命令参数
选项 | 含义 |
-m | 当指定的任务被完成后,将给用户发送邮件,即使没有标准输出 |
-I | atq的别名 |
-d | atrm的别名 |
-v | 显示任务将被执行的时间 |
-c | 打印任务的内容到标准输出 |
-V | 显示版本信息 |
-q <队列> | 使用指定的队列 |
-f <文件> | 从指定文件读入任务而不是从标准输入读入 |
-t <时间参数> | 以时间参数的形式提交要运行的任务 |
配置文件
- 时间规范的确切定义可以在/usr/share/doc/at-3.1.13/timespec中查看;
- 默认情况下计划任务都是存放在/var/spool/at/文件夹中;
- root用户可以在任何情况下使用at命令,而其他用户使用at命令的权限定义在/etc/at.allow(被允许使用计划任务的用户)和/etc/at.deny(被拒绝使用计划任务的用户)文件中,默认没有文件需要自己创建允许用户和拒绝用户文件;
- 如果/etc/at.allow文件存在,只有在该文件中的用户名对应的用户才能使用at;
- 如果/etc/at.allow文件不存在,/etc/at.deny存在,所有不在/etc/at.deny文件中的用户可以使用at;
- at.allow比at.deny优先级高,执行用户是否可以执行at命令,先看at.allow文件中有没有才看at.deny文件;
- 如果/etc/at.allow和/etc/at.deny文件都不存在,则只有root用户能使用at;
- 一个空内容的/etc/at.deny表示任何用户都能使用at命令,这是默认的配置;
- 一般情况下这两个文件存在一个即可。如果只有少数几个用户需要使用计划任务,那么就保留at.allow文件,如果大部分用户都要使用计划任务,那么保留at.deny即可。
使用案例
案例1:明天17点钟,输出时间到指定文件内
[root@vms002 /]# at 17:00 tomorrow
at> date > /root/date.log
at> <EOT>
job 2 at Wed Jun 12 17:00:00 2019
案例2:三天后的下午5点执行/bin/ls /
[root@vms002 /]# at 5pm+3 days
at> /bin/ls /<EOT>
job 1 at Fri Jun 14 17:00:00 2019
案例3:计划任务设定后,在没有执行之前我们可以用atq命令来查看系统中没有执行的工作任务
[root@vms002 /]# atq
1 Fri Jun 14 17:00:00 2019 a root
2 Wed Jun 12 17:00:00 2019 a root
案例4:删除已经设置的任务
[root@vms002 /]# atq
1 Fri Jun 14 17:00:00 2019 a root
2 Wed Jun 12 17:00:00 2019 a root
[root@vms002 /]# atrm 1
[root@vms002 /]# atq
2 Wed Jun 12 17:00:00 2019 a root
案例5:显示已经设置的任务内容
[root@vms002 /]# at -c 2
#!/bin/sh
# atrun uid=0 gid=0
# mail root 0
umask 22
******此处省略部分内容*****
date > /root/date.log
参考
linux定时任务 - at定时任务https://www.cnblogs.com/houss/p/13321869.html