Linux中的计划任务—Crontab调度一次性执行的任务at/batch

简介: Linux中的计划任务—Crontab调度一次性执行的任务at/batch

概述

前不久我们梳理了Linux中的计划任务—Crontab调度重复执行的任务,但是有些场景我们只是需要执行一次,执行完就结束任务该怎么办呢? 这里我们要用到linux提供的at/batch命令。

本篇博文我们将从如下几个要点来阐述:

  • 提交at作业(命令或者shell脚本),使之在某个指定时间开始执行
  • 显示或者删除已经提交的at作业
  • 控制用户是否能够使用at命令提交定时作业

以下实例为Centos6.5操作系统的演示结果


服务启动

默认情况下所有的linux系统都提供此项功能。在redhat中atd是默认随系统启动而启动。

[root@entel2 ~]# ps -ef | grep atd #查看atd服务
rpcuser   5544     1  0 Sep28 ?        00:00:00 rpc.statd
root      6012     1  0 Sep28 ?        00:00:00 /usr/sbin/atd
root      8651  8543  0 15:58 pts/0    00:00:00 grep atd
[root@entel2 ~]# service atd status  #查看atd服务状态
atd (pid  6012) is running...
[root@entel2 ~]# chkconfig --help
chkconfig version 1.3.49.3 - Copyright (C) 1997-2000 Red Hat, Inc.
This may be freely redistributed under the terms of the GNU Public License.
usage:   chkconfig [--list] [--type <type>] [name]
         chkconfig --add <name>
         chkconfig --del <name>
         chkconfig --override <name>
         chkconfig [--level <levels>] [--type <type>] <name> <on|off|reset|resetpriorities>
[root@entel2 ~]# chkconfig --level 2345 atd on  #开机启动atd服务
[root@entel2 ~]# 
[root@entel2 ~]# /etc/init.d/atd start #启动atd服务
[root@entel2 ~]# /etc/init.d/atd restart
Stopping atd:                                      [  OK  ]
Starting atd:                                      [  OK  ]
[root@entel2 ~]# service atd start  #启动atd服务
[root@entel2 ~]# service atd restart #重启atd服务
Stopping atd:                                      [  OK  ]
Starting atd:                                      [  OK  ]
[root@entel2 ~]# service atd # atd服务支持的参数
Usage: /etc/init.d/atd {start|stop|status|restart|condrestart|try-restart|reload|force-reload}

语法

at [-mld] time [date]

参数详解

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

-I atq的别名

-d atrm的别名

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

-c 打印任务的内容到标准输出

-V 显示版本信息

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

-f<文件> 从指定文件读入任务而不是从标准输入读入

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

示例:

[root@entel2 ~]# at -v
Garbled time
[root@entel2 ~]# at -V
at version 3.1.10

time 详解

time 可以是 1,2或者4位数字,以时分形式(HHMM或者HH:MM)指定作业开始运行的时间

如果指定的时间为整点时间(1或者2位数字),分可以省略

如果按12小时指定时间,时间后面应该加am或者pm

其他可以接受的关键字是midnight 、noon 和 now

能够使用相对计时法。指定格式为:now + count time-units ,now就是当前时间,time-units是时间单位,这里能够是minutes(分钟)、hours(小时)、days(天)、weeks(星期)。count是时间的数量,几天,几小时。

date 详解

date是以月 日 年(MMDDYY、MM/DD/YY或者MM.DD.YY)

“月名 日 (如 June 1)”、星期几(如Monday)、关键字today或者tomorrow等标识的日期

为了简化输入,也可以使用月,星期几或者其他关键字的前三个字符

通常,任何用户都可以创建 显示 删除自己的at作业文件,但只有root用户才有权限访问其他用户的at作业。

当利用at或者batch提交at作业后,系统会以文件的形式保存提交的at作业,并存储在 /var/spool/cron/atjobs目录中,由cron守护进程负责处理at或者batch命令形式提交的作业

at作业文件采用一串数字加一个.a 或者.b扩展名命名。

数字表示作业在at作业队列中的位置

文件名后缀表示作业类型,

a表示at提交的作业 b表示batch命令提交的作业


栗子

提交at作业

提交at作业三要素:

  • 输入at命令
  • 指定作业执行时间
  • 输入准备执行的命令或者shell脚本

为了提交一个at作业步骤:

  1. 输入at命令同时指定作业执行的时间 ,按下Enter键;
  2. 在at命令提示符“at >”下,输入命令或者shell脚本
  3. Ctrl+D 提交at作业。

在16点48分执行 pwd 和 ls 命令

[root@entel2 cron]# at 1648
at> pwd&&ls<EOT>
job 2 at 2016-10-15 16:48

执行日志 在 /var/spool/mail/root文件中

如果希望同时输入多个命令或者shell脚本,每个命令或者shell脚本应该占一行,以Enter键结束,按下Ctrl-D提交作业。

[root@entel2 cron]# at 1715
at> pwd
at> ll
at> 
at> <EOT>
job 4 at 2016-10-15 17:15
[root@entel2 cron]# atq
4   2016-10-15 17:15 a root
1   2016-10-15 16:50 a root

提交batch作业

当需要提交一个作业而不关系其究竟何时执行时,可以使用batch命令。batch不需要指定时间,因为它会自动在系统负载比较低的时候执行(平均负载小于0.8的时候)

[root@entel2 cron]# batch
at> date<EOT>
job 5 at 2016-10-15 17:42

显示at作业及作业队列

查询已经创建,目前仍然在at队列中的作业,可以直接访问/var/spool/cron/atjobs目录 (可能没有该目录哦~)

或者 atq 或者 at -l

[root@entel2 ~]# atq 
1   2016-10-15 16:50 a root
5   2016-10-15 17:42 b root
[root@entel2 ~]# at -l
1   2016-10-15 16:50 a root
5   2016-10-15 17:42 b root

显示已经设置的任务内容

命令:

at -c 任务号
[root@entel2 /]# at tomorrow
at> ls<EOT>
job 7 at 2016-10-16 18:35
[root@entel2 /]# atq
7   2016-10-16 18:35 a root
[root@entel2 /]# at -c 7  #看倒数第二行
#!/bin/sh
# atrun uid=0 gid=0
# mail root 0
umask 22
HOSTNAME=entel2; export HOSTNAME
SHELL=/bin/bash; export SHELL
HISTSIZE=1000; export HISTSIZE
......省略
}
${SHELL:-/bin/sh} << 'marcinDELIMITER6e198d77'
ls
marcinDELIMITER6e198d77

三部分

  • 第一部分:完成后是否电邮通知用户等
  • 第二部分:主要是环境变量设置
  • 第三部分:需要执行的实际命令

删除at作业

使用atrm命令可以将已添加的未执行计划任务删除,格式为“atrm 任务号”比如:atrm 5 或者 atrm 文件名

或者使用atrm的别名 at -d 任务号at -d 文件名

[root@entel2 /]# atq #查询
1   2016-10-15 16:50 a root
5   2016-10-15 17:42 b root
[root@entel2 /]# atrm 5 #删除任务号为5的job
[root@entel2 /]# atq #查询
1   2016-10-15 16:50 a root

任何用户都可以从队列中删除自己的at作业

只有root用户才能删除其他用户的at作业

root 如果未指定用户名,则删除自己的at作业。


at命令的访问控制

at命令使用的控制文件来限制用户的使用控制

控制文件目录:/etc/at.allow/etc/at.deny (只有root用户才可以访问)

控制文件使用规则:

  • 1:先找寻 /etc/at.allow 这个文件,写在这个文件中的使用者才能使用 at ,没有在这个文件中的使用者则不能使用 at
    (即使没有写在 at.deny 当中);
  • 2:如果 /etc/at.allow 不存在,就寻找 /etc/at.deny 这个文件,若写在这个 at.deny 的使用者则不能使用at ,而没有在这个 at.deny 文件中的使用者就可以使用 at 命令。 Unix通常不提供at.allow文件
  • 3:如果两个文件都不存在,那么只有 root 可以使用 at 这个命令。
  • 4:在一般的 distributions 当中,由于假设系统上的所有用户都是可信任的, 因此系统通常会保留一个空的
    /etc/at.deny 文件,意思是允许所有人使用 at 命令的意思。
  • 5:如果不希望有某些使用者使用 at 的话,将那个使用者的帐号写入 /etc/at.deny 即可! 一个帐号写一行。

# vi /etc/at.allow

注意事项

1、如果at的指令输出的路径有误 则会把结果以邮件的形式发送给用户

2、当一个任务创建了会被分配到一个任务号,而且会在/var/spool/at里面排队。不建议使用vi编辑器去修改,容易出错。


实例:系统定时关机

# at 1430
at> init 0
at> <EOT>
.........


相关文章
|
1月前
|
监控 安全 Linux
在 Linux 系统中,网络管理是重要任务。本文介绍了常用的网络命令及其适用场景
在 Linux 系统中,网络管理是重要任务。本文介绍了常用的网络命令及其适用场景,包括 ping(测试连通性)、traceroute(跟踪路由路径)、netstat(显示网络连接信息)、nmap(网络扫描)、ifconfig 和 ip(网络接口配置)。掌握这些命令有助于高效诊断和解决网络问题,保障网络稳定运行。
75 2
|
1月前
|
人工智能 算法 大数据
Linux内核中的调度算法演变:从O(1)到CFS的优化之旅###
本文深入探讨了Linux操作系统内核中进程调度算法的发展历程,聚焦于O(1)调度器向完全公平调度器(CFS)的转变。不同于传统摘要对研究背景、方法、结果和结论的概述,本文创新性地采用“技术演进时间线”的形式,简明扼要地勾勒出这一转变背后的关键技术里程碑,旨在为读者提供一个清晰的历史脉络,引领其深入了解Linux调度机制的革新之路。 ###
|
1月前
|
算法 Linux 定位技术
Linux内核中的进程调度算法解析####
【10月更文挑战第29天】 本文深入剖析了Linux操作系统的心脏——内核中至关重要的组成部分之一,即进程调度机制。不同于传统的摘要概述,我们将通过一段引人入胜的故事线来揭开进程调度算法的神秘面纱,展现其背后的精妙设计与复杂逻辑,让读者仿佛跟随一位虚拟的“进程侦探”,一步步探索Linux如何高效、公平地管理众多进程,确保系统资源的最优分配与利用。 ####
71 4
|
1月前
|
缓存 负载均衡 算法
Linux内核中的进程调度算法解析####
本文深入探讨了Linux操作系统核心组件之一——进程调度器,着重分析了其采用的CFS(完全公平调度器)算法。不同于传统摘要对研究背景、方法、结果和结论的概述,本文摘要将直接揭示CFS算法的核心优势及其在现代多核处理器环境下如何实现高效、公平的资源分配,同时简要提及该算法如何优化系统响应时间和吞吐量,为读者快速构建对Linux进程调度机制的认知框架。 ####
|
26天前
|
缓存 算法 Linux
Linux内核中的调度策略优化分析####
本文深入探讨了Linux操作系统内核中调度策略的工作原理,分析了不同调度算法(如CFS、实时调度)在多核处理器环境下的性能表现,并提出了针对高并发场景下调度策略的优化建议。通过对比测试数据,展示了调度策略调整对于系统响应时间及吞吐量的影响,为系统管理员和开发者提供了性能调优的参考方向。 ####
|
2月前
|
Linux
Linux Crontab 查看定时任务启动没
【10月更文挑战第20天】在Linux系统中,crontab用于设置周期性执行的任务。查看当前用户的Crontab任务列表,使用`crontab -l`;查看所有用户任务,使用`sudo crontab -l`或指定用户`sudo crontab -u username -l`。
93 5
|
3月前
|
消息中间件 分布式计算 Java
Linux环境下 java程序提交spark任务到Yarn报错
Linux环境下 java程序提交spark任务到Yarn报错
51 5
|
4月前
|
监控 Linux 调度
在Linux中,如何进行调度任务?什么是 crontab 并解释 crontab 中的字段?
在Linux中,如何进行调度任务?什么是 crontab 并解释 crontab 中的字段?
|
3月前
|
Linux 调度
linux中几种任务的优先级
linux中几种任务的优先级
|
4月前
|
负载均衡 算法 Linux
在Linux中,LVS的负载调度算法是什么?
在Linux中,LVS的负载调度算法是什么?