Linux命令--定时运行程序(脚本)--方法/实例

原文网址:Linux命令--定时运行程序(脚本)--方法/实例_IT利刃出鞘的博客-CSDN博客

简介

说明

本文介绍Linux如何定时运行程序。

概述

at命令是一次性定时计划任务,执行完一个任务后不再执行此任务了。

相关命令

  • at:在特定的时间执行一次性的任务;
  • atq:列出用户的计划任务,若是超级用户将列出所有用户的任务,输出格式为:作业号、日期、小时、队列和用户名;
  • atrm:根据job number删除at任务;
  • batch:在系统负荷允许的情况下执行at任务,就是在系统空闲的情况下才执行at任务。

示例1:三天后的下午5点执行/bin/ls /

需求

三天后的下午5点执行命令:/bin/ls /

方法

[root@vms002 /]# at 5pm+3 days
at> /bin/ls /<EOT>
job 1 at Fri Jun 14 17:00:00 2019

示例2:一分钟后执行文件中的命令

需求

一分钟后执行/tmp/date文件中的内容。

方法

[root@vms002 /]# cat /tmp/date        #查看/tmp/date文件中内容
#!/bin/bash
date "+%F %T" > /root/date.log
[root@vms002 /]# at -f /tmp/date now +1 minutes   #设置1分钟后执行/tmp/date文件中的内容
job 4 at Tue Jun 11 15:47:00 2019

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 <时间参数>

以时间参数的形式提交要运行的任务

指定时间的方法

  • hh:mm(小时:分钟)式的时间指定。假如该时间已过去,那么就放在第二天执行。 例如:04:00
  • 12小时计时制。即在时间后面加上AM(上午)或PM(下午)来说明是上午还是下午。 例如:12pm
  • 具体日期。指定格式为month day(月 日)或mm/dd/yy(月/日/年)或dd.mm.yy(日.月.年),指定的日期必须跟在指定时间的后面。 例如:04:00 2009-03-1
  • 相对计时法。指定格式为:now + count time-units ,now就是当前时间,time-units是时间单位,这里能够是minutes(分钟)、hours(小时)、days(天)、weeks(星期)。count是时间的数量,几天,几小时。 例如:now + 5 minutes + 3 days
  • 模糊时间段。midnight(深夜),noon(中午),teatime(饮茶时间,一般是下午4点)等模糊的词语来指定时间。
  • today(今天)、tomorrow(明天)来指定完成命令的时间。例如:at 17:00 tomorrow

相关配置文件

  • 时间规范的确切定义可以在/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即可。
  • 7
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

IT利刃出鞘

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值