at定时执行任务命令

windows系统中,windows提供了计划任务这一功能,在控制面板 -> 性能与维护 -> 任务计划, 它的功能就是安排自动运行的任务。 通过'添加任务计划'的一步步引导,则可建立一个定时执行的任务。

linux系统中你可能已经发现了为什么系统常常会自动的进行一些任务?这些任务到底是谁在支配他们工作的?在linux系统如果你想要让自己设计的备份程序可以自动在某个时间点开始在系统底下运行,而不需要手动来启动它,又该如何处置呢? 这些例行的工作可能又分为一次性定时工作与循环定时工作,在系统内又是哪些服务在负责? 还有,如果你想要每年在老婆的生日前一天就发出一封信件提醒自己不要忘记,linux系统下该怎么做呢? 

今天我们主要学习一下一次性定时计划任务的at命令的用法!

1.命令格式:

at[参数][时间]

时间格式:

HH:MM [YYYY-mm-dd]:直接指明具体的时间

noon,midnight, teatime:中

now+#:现在之后的多久,可使用表示单位为minutes, hours, days, OR weeks

2.命令功能:

在一个指定的时间执行一个指定任务,只能执行一次,且需要开启atd进程

ps -ef | grep atd查看, 开启用/etc/init.d/atd start or restart; 开机即启动则需要运行 chkconfig --level 2345 atd on)。

3.命令参数:

   -m 当指定的任务被完成之后,将给用户发送邮件,即使没有标准输出

   -l 查看作业队列,相当于atq

   -d 删除指定的作业,相当于atrm

   -v 显示任务将被执行的时间

   -c 查看指定作业的具体内容

   -V 显示版本信息

   -q<列队> 使用指定的列队

   -f<文件> /PATH/FROM/SOMEFILE:从指定文件中读取作业任务,不用交互式输入

   -t<时间参数> 以时间参数的形式提交要运行的任务

4.Ctrl+D:提交一次性任务,退出at


检查at是否安装

在使用前先使用whereis命令检查at命令是否安装,如果没有安装执行下面的yum命令进行安装(安装过程输出内容省略)

[root@a ~]# yum provides at
Loaded plugins: fastestmirror
Loading mirror speeds from cached hostfile
at-3.1.10-48.el6.x86_64 : Job spooling tools
Repo        : base
Matched from:

[root@a ~]# yum -y install at-3.1.10-48.el6.x86_64

开启atd服务并设置开机自动启动

centos6:

[root@a ~]# service atd start
Starting atd:                                              [  OK  ]
[root@a ~]# service atd status
atd (pid  1832) is running...
[root@a ~]# chkconfig --level 3 atd on
[root@a ~]# chkconfig --list | grep atd
atd             0:off   1:off   2:off   3:on    4:on    5:on    6:off

有些Linux版本需要用 /etc/init.d/atd start 开启 atd 服务
用法:/etc/init.d/atd {start|stop|restart|condrestart|status}

相关配置文件

  • 时间规范的确切定义可以在/usr/share/doc/at-3.1.10/timespec中查看
  • root用户可以在任何情况下使用at命令,而其他用户使用at命令的权限定义在/etc/at.allow和/etc/at.deny文件中
  • 如果/etc/at.allow文件存在,只有在该文件中的用户名对应的用户才能使用at
  • 如果/etc/at.allow文件不存在,/etc/at.deny存在,所有不在/etc/at.deny文件中的用户可以使用at
  • 如果/etc/at.allow和/etc/at.deny文件都不存在,只有root用户能使用at
  • 一个空内容的/etc/at.deny表示任何用户都能使用at命令,这是默认的配置

 at 的运行方式

既然是计划任务,那么应该会有任务执行的方式,并且将这些任务排进行程表中。那么产生计划任务的方式是怎么进行的? 事实上,我们使用 at 这个命令来产生所要运行的计划任务,并将这个计划任务以文字档的方式写入 /var/spool/at/ 目录内,该工作便能等待 atd 这个服务的取用与运行了。就这么简单。

不过,并不是所有的人都可以进行 at 计划任务。为什么? 因为系统安全的原因。很多主机被所谓的攻击破解后,最常发现的就是他们的系统当中多了很多的黑客程序, 这些程序非常可能运用一些计划任务来运行或搜集你的系统运行信息,并定时的发送给黑客。 所以,除非是你认可的帐号,否则先不要让他们使用 at 命令。那怎么达到使用 at 的可控呢?

我们可以利用 /etc/at.allow 与 /etc/at.deny 这两个文件来进行 at 的使用限制。加上这两个文件后, at 的工作情况是这样的:

先找寻 /etc/at.allow 这个文件,写在这个文件中的使用者才能使用 at ,没有在这个文件中的使用者则不能使用 at (即使没有写在 at.deny 当中);

如果 /etc/at.allow 不存在,就寻找 /etc/at.deny 这个文件,若写在这个 at.deny 的使用者则不能使用 at ,而没有在这个 at.deny 文件中的使用者,就可以使用 at 命令了。

如果两个文件都不存在,那么只有 root 可以使用 at 这个命令。

透过这个说明,我们知道 /etc/at.allow 是管理较为严格的方式,而 /etc/at.deny 则较为松散 (因为帐号没有在该文件中,就能够运行 at 了)。在一般的 distributions 当中,由于假设系统上的所有用户都是可信任的, 因此系统通常会保留一个空的 /etc/at.deny 文件,意思是允许所有人使用 at 命令的意思 (您可以自行检查一下该文件)。 不过,万一你不希望有某些使用者使用 at 的话,将那个使用者的帐号写入 /etc/at.deny 即可! 一个帐号写一行。



*** 在初用 at时不知道怎么退出害羞

     1、输入 “at指定的时间” 之后回车

     2、然后输入要运行的命令,回车,按组合键 Ctrl+D

*** 在linux中 crontab 用于处理周期性的任务而 at 则是处理仅执行一次的任务.

atbatch都可以一次性任务计划。但batch系统自行选择在系统资源较空闲的时间去执行指定的任务;at:指定未来的某时间点执行一次某任务。


猜你喜欢

转载自blog.csdn.net/eddjh_31/article/details/76673696