在Linxu系统中,有三种用于任务调度的工具

  • at命令调用atd服务
  • crontab命令调用cron(crond)服务。
  • anacron工具。

1、任务调度工具anacron介绍

(1)anacron工具是用来干什么的呢?

如果Linux服务器不是24小时开机的,那么刚好在关机的时间段之内有系统定时任务(cron)需要执行,那么这些定时任务是不会执行的。

假设我们需要在凌晨3点03分执行系统的日志备份,但是我们的Linux服务器不是24小时开机的,在晚上需要关机,白天上班之后才会再次开机。这个定时任务的执行时间,我们的服务器刚好没有开机,那么这个任务就不会执行了,anacron工具就是用来解决这个问题的。

anacron工具会使用一天,七天,一个月作为检测周期,用来判断是否有定时任务在关机之后没有被执行,如果有这样的任务,anacron工具会在特定的时间重新执行这些定时任务。

anacron工具以天为单位,周期性地执行命令。anacron是以天为单位,而 cron最小执行的周期是分钟。

(2)那么anacron工具是如何判断这些定时任务已经超过了执行时间的呢?

在系统的/var/spool/anacron/目录中存在cron.{daily,weekly,monthly}文件,这些文件中都保存着anacron工具上次执行时的时间。anacron工具会去读取这些文件中的时间,然后和当前时间做比较,若果两个时间的差值超过了anacron工具配置文件中的指定时间差值(一般是1天,7天和一个月)(/etc/anacrontab文件),就说明有定时任务漏掉了没有被执行,这时anacron工具会介入而执行这个漏掉的定时任务,从而保证在关机时没有被执行的定时任务,不会被漏掉。

2、新旧版本Linux中anacron工具的区别

在原先的CentOS 5.x版中/etc/cron.{daily,weekly,monthly}这些目录中的定时任务会同时被cron工具和anacron工具调用,这样非常容易出现重复执行同一个定时任务的错误。

CentOS 6.x中,我们使用cronie-anacron取代了vixie-cron软件包。/etc/cron.{daily,weekly,monthly}目录中的定时任务程序只会被anacron工具调用,从而保证这些定时任务只会在每天、每周或每月被定时执行一次,而不会重复执行。这也是我们在上一篇文章中介绍的CentOS 6.x的变化之一。

3、/etc/cron.{daily,weekly,monthly}目录说明

/etc目录下面有crontab的两个文件crontabcron.deny,还有五个目录cron.dcron.dailycron.hourlycron.monthlycron.weekly

如下图所示:

说明:

  • cron.deny:文件就是用于控制不让哪些用户使用Crontab的功能。
  • crontab:是设定定时任务执行文件。
  • cron.d:是系统自动定期需要做的任务。
  • cron.daily:是每天执行一次的job
  • cron.hourly:是每个小时执行一次的job
  • cron.monthly:是每月执行一次的job
  • cron.weekly:是每个星期执行一次的job

4、anacron命令

CentOS 6.xanacron命令还有一个变化,anacron工具不再是单独的服务,而变成了系统命令。也就是说我们不再可以使用service anacron restart命令来管理anacron服务了。而是需要使用anacron命令来管理anacron工具工作,具体命令如下:

[root@localhost ~]# anacron [选项] [工作名]

选项:
-s:开始anacron工作,依据/etc/anacrontab文件中的设定的延迟时间执行。
-n:立即执行/etc/anacrontab中所有的工作,忽略所有的延迟时间。
-u:更新/var/spool/anacron/cron.{dai ly,weekly,monthly}文件中的时间戳,但不执行任何工作 参数:
工作名:是依据/etc/anacrontab文件中定义的工作名

在Linux 6版本中,其实不需要执行任何anacron命令,只需要配置好/etc/anacrontab文件,系统就会依赖这个文件中的设定,来通过anacron工具执行定时任务。

那么关键就是/etc/anacrontab文件的内容了,这个文件如下:

# 在vim编辑器中打开/etc/anacrontab文件
[root@localhost ~]# vim /etc/anacrontab # 下面是/etc/anacrontab文件内容 # /etc/anacrontab: configuration file for anacron # See anacron(8) and anacrontab(5) for details. # 前面的内容和/etc/crontab类似都是一些变量的设置
# 标识使用哪种shell
SHELL=/bin/sh
# 指定PATH环境变量,crontab是使用自己的PATH,
# 而不是用系统默认的,所以在定时任务中出现的命令最好使用绝对路径。
PATH=/sbin:/bin:/usr/sbin:/usr/bin
# 如果有报错输出,或命令结果有输出,会向root发信息
MAILTO=root # the maximal random delay added to the base delay of the jobs
# 最大随机延迟。
# 意思是:服务器开机以后,会和`/var/spool/anacron/`目录中文件的内容对比时间
# 发现超过一天,那`/etc/cron.{daily,weekly,monthly}`这些目录中的可执行文件
# 就都会被执行,这么多可执行脚本不能同时执行,那样服务器的负载会非常大。
# 在开机45分钟之内,给每个一脚本随机一个时间,一个一个来执行。
RANDOM_DELAY=45 # the jobs will be started during the following hours only
# 设置允许anacron的执行时间范围是3:00-22:00
# 这个可以按照自己的需求修改。
START_HOURS_RANGE=3-22 # 下面就是我们的定时任务
# 意思是:时间差超过天数时,强制延迟多少分钟之后,就执行命令
#天数 强制延迟(分) 工作名称 实际执行的命令
#period in days delay in minutes job-identifier command
1 5 cron.daily nice run-parts /etc/cron.daily
7 25 cron.weekly nice run-parts /etc/cron.weekly
@monthly 45 cron.monthly nice run-parts /etc/cron.monthly

说明:在上面文件中

  • RANDOM_DELAY定义的是最大随机延迟,也就是说cron.daily任务如果超过1天没有执行,并不会马上执行,而是先延迟强制延迟时间之后,再延迟随机延迟时间之后再执行命令。
  • START_HOURS_RANGE定义anacron的执行时间范围,anacron只会在这个时间范围之内执行。
  • period in days执行周期;最小 1 天,也可以 3 天,5 天,一个星期(7 天)乃至一个月(月份不能确定有多少天,所以用@monthly代替)。
  • delay in minutes延迟多长时间执行,以分钟为单位。为了避免多个任务在同一时间执行而造成服务器繁忙,所以应该错峰执行。
  • job-identifier 任务的唯一标识。它用来创建文件记录任务执行的时间,通常创建在/var/spool/anacron/目录中。
  • command真正执行的命令。

5、/etc/anacrontab的执行过程

我们用上面配置文件中的cron.daily工作来说明下/etc/anacrontab的执行过程:

  1. 首先读取/var/spool/anacron/cron.daily中的上一次anacron执行的时间.
  2. 和当前时间比较,如果两个时间的差值超过1天,就执行cron.daily工作。
  3. 执行这个工作只能在03:00-22:00之间。
  4. 执行工作时强制延迟时间为5分钟,再随机延迟0-45分钟时间。
  5. 使用nice命令指定默认优先级,使用run-parts脚本执行/etc/cron.daily目录中的所有可执行文件。

大家发现了吧,/etc/cron.{daily,weekly,monthly}中的脚本,在当前的Linux中是被anacron调用的,不再依靠cron服务。(最重要的你要知道:无论在新旧版本的Linux系统中,/etc/cron.{daily,weekly,monthly}目录中的脚本文件,都是可以被正常执行的,关于是cron工具和anacron工具谁来调用的,你可以不用关心。)不过anacron不用设置多余的配置,我们只需要把需要定时执行的脚本放入/etc/cron.{daily,weekly,monthly}目录当中,就会每天、每周或每月执行,而且也不再需要启动anacron服务了,因为anacron命令是一个系统命令。

『学了就忘』Linux系统定时任务 — 89、任务调度工具anacron的更多相关文章

  1. 『学了就忘』Linux系统定时任务 — 87、只执行一次的定时任务

    目录 1.at服务管理 2.at命令的访问控制 3.at命令 4.其他at管理命令 5.总结 定时任务是在服务器上常用到的一个工作. 在你指定的时间,系统会自动执行你指定的程序(脚本或者命令). Li ...

  2. 『学了就忘』Linux系统定时任务 — 88、循环执行定时任务

    目录 1.crond服务管理与访问控制 2.crontab命令的访问控制 3.用户级别的crontab命令 4.crontab命令的注意事项 5.系统的crontab设置 (1)/etc/cronta ...

  3. 『学了就忘』Linux软件包管理 — 49、拓展:Linux中通过脚本安装程序

    目录 1.脚本程序简介 2.Webmin安装 (1)简介 (2)安装 (3)使用 1.脚本程序简介 脚本程序包并不多见,所以在软件包分类中并没有把它列为一类.它更加类似于Windows下的程序安装,有 ...

  4. 『学了就忘』Linux基础 — 6、VMware虚拟机安装Linux系统(超详细)

    目录 1.打开VMware虚拟机软件 2.选择Linux系统的ISO安装镜像 3.开启虚拟机安装系统 (1)进入Linux系统安装界面 (2)硬件检测 (3)检测光盘 (4)欢迎界面 (5)选择语言 ...

  5. 『学了就忘』Linux基础 — 7、补充:安装Linxu系统时设置硬盘挂载说明

    目录 (1)新建一个/home分区 (2)再创建一个/boot分区. (3)创建一个swap分区 (4)最后剩余的空间全部分给根目录 (5)总结 上一篇在VMwar虚拟机中安装Linux操作系统中ht ...

  6. 『学了就忘』Linux基础 — 11、通过setup工具配置Linux系统IP地址

    目录 1.setup命令介绍 2.使用setup命令配置IP (1)执行setup命令 (2)进入图形化配置界面 (3)选择配置IP还是DNS (4)选择要配置的网卡 (5)进入IP地址配置页面 (6 ...

  7. 『学了就忘』Linux基础 — 13、Linux系统的分区和格式化

    目录 1.Linux系统的分区 (1)磁盘分区定义 (2)两种分区表形式 (3)MBR分区类型 2.Linux系统的格式化 (1)格式化定义 (2)格式化说明 1.Linux系统的分区 (1)磁盘分区 ...

  8. 『学了就忘』Linux基础 — 14、Linux系统的设备文件名和挂载

    目录 1.设备文件名 (1)为什么需要设备文件名 (2)硬件设备文件名命名规则 2.挂载点 3.挂载 (1)什么是挂载 (2)挂载前的分区要求 (3)小结(重点) 1.设备文件名 (1)为什么需要设备 ...

  9. 『学了就忘』Linux基础 — 15、了解Linux系统的目录结构

    目录 1.一级目录说明 (1)一级目录列表 (2)/bin/和/sbin/目录说明 (3)/boot/目录说明 (4)/lib/和/lib64/目录说明 (5)/lost+found/目录说明 (6) ...

随机推荐

  1. shell常用集锦

    该文整理一些常用的shell用法,及语法,并非介绍如何使用 变量 变量可分为两类:环境变量ENV(全局)和局部变量. bash环境变量 变量名 含义 _= 上一条命令的最后一个参数 BASH_VERS ...

  2. SpringBoot集成邮件发送

    一:简述 在日常中的工作中难免会遇到程序集成邮件发送功能.接收功能:此篇文章我将使用SpringBoot集成邮件发送功能和接收功能:若对邮件一些基本协议和发送流程不懂的请务必参考我之前写的博客或者浏览 ...

  3. Ubuntu 18.04.5 LTS Ceph集群之 cephx 认证及使用普通用户挂载RBD和CephFS

    1.cephx认证和授权 1.1 CephX认证机制 Ceph使用cephx协议对客户端进行身份认证: 1.每个MON都可以对客户端进行身份验正并分发密钥, 不存在单点故障和性能瓶颈 2. MON会返 ...

  4. Python基础之流程控制if判断

    目录 1. 语法 1.1 if语句 1.2 if...else 1.3 if...elif...else 2. if的嵌套 3. if...else语句的练习 1. 语法 1.1 if语句 最简单的i ...

  5. MySQL 的查询优化

    说起 MySQL 的查询优化,相信大家收藏了一堆奇技淫巧:不能使用 SELECT *.不使用 NULL 字段.合理创建索引.为字段选择合适的数据类型..... 你是否真的理解这些优化技巧?是否理解它背 ...

  6. JavaBean内省与BeanInfo

    Java的BeanInfo在工作中并不怎么用到,我也是在学习spring源码的时候,发现SpringBoot启动时候会设置一个属叫"spring.beaninfo.ignore", ...

  7. Spring Security 基于URL的权限判断

    1.  FilterSecurityInterceptor 源码阅读 org.springframework.security.web.access.intercept.FilterSecurityI ...

  8. nodeJs-Stream接口

    JavaScript 标准参考教程(alpha) 草稿二:Node.js Stream接口 GitHub TOP Stream接口 来自<JavaScript 标准参考教程(alpha)> ...

  9. 双向循环链表模板类(C++)

    双向链表又称为双链表,使用双向链表的目的是为了解决在链表中访问直接前驱和后继的问题.其设置前驱后继指针的目的,就是为了节省其时间开销,也就是用空间换时间. 在双向链表的每个节点中应有两个链接指针作为它 ...

  10. Java 性能优化的 50 个细节

    在JAVA程序中,性能问题的大部分原因并不在于JAVA语言,而是程序本身.养成良好的编码习惯非常重要,能够显著地提升程序性能. #尽量在合适的场合使用单例 使用单例可以减轻加载的负担,缩短加载的时间, ...