定时任务的使用场景非常广泛,比如定时发送邮件,定时清理日志等等,在持续集成中,可以定时地触发测试任务,比如希望在每天晚上下班时间执行自动化用例。本文通过介绍linux cron定时来了解cron定时相关概念。
cron来源于希腊语chronos,意思是时间。在类Unix的操作系统中,可以使用cron 服务器来实现定时执行任务。crontab文件存放cron指令,执行周期命令的守护进程crond负责激活这些任务,定期检查是否有任务执行。
crond 服务是用来执行周期任务或等待处理某些事件的一个守护进程,crontab 命令需要 crond 服务支持。centos7中一般是默认安装的,可以使用 rpm 命令查看是否安装:
$ rpm -qa | grep crontab
crontabs-1.11-6.20121102git.el7.noarch
查看crond 服务状态:
# centos7
systemctl status crond.service
# centos6
service crond status
启动crond 服务:
# centos7
systemctl start crond.service
# centos6
service crond start
停止crond 服务:
# centos7
systemctl stop crond.service
# centos6
service crond stop
重启crond 服务:
# centos7
systemctl restart crond.service
# centos6
service crond restart
重载crond 服务:
# centos7
systemctl reload crond.service
# centos6
service crond reload
cron 服务主要包括以下文件目录:
/etc/crontab文件负责管理和维护任务:
$ cat /etc/crontab
SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root
# For details see man 4 crontabs
# Example of job definition:
# .---------------- minute (0 - 59)
# | .------------- hour (0 - 23)
# | | .---------- day of month (1 - 31)
# | | | .------- month (1 - 12) OR jan,feb,mar,apr ...
# | | | | .---- day of week (0 - 6) (Sunday=0 or 7) OR sun,mon,tue,wed,thu,fri,sat
# | | | | |
# * * * * * user-name command to be executed
其中:
用户定义的crontab文件保存在 /var/spool/cron 目录中,每个crontab任务以创建者的名字命名。crontab文件中每一行都代表一项任务,每条命令包括6个字段,前5个代表时间,第6个字段是要执行的命令。
五颗星:* * * * *
可以使用4种操作符:
下面举几个例子:
# 每5分钟构建一次
H/5 * * * *
# 每2小时构建一次
H H/2 * * *
# 每天8点到22点,每2小时构建一次
H 8-22/2 * * *
# 每天8点,22点各构建一次
H 8,22 * * *
crontab 命令用来配置定时任务,语法如下:
crontab [options] file
crontab [options]
常用options:
先写一个用于采集CPU性能信息的脚本(cpu_Perf.sh):
#!/bin/bash
mpstat -P ALL 1 2 >> /var/cron/perf.log
下面来添加一个定时任务:
执行 命令crontab -e ,输入下面的cron表达式,每分钟执行一次CPU性能采集脚本:
* * * * * /var/cron/cpu_Perf.sh
保存。命令保存到了 /var/spool/cron/ 目录下的root文件中(当前用户为root):
$ cat /var/spool/cron/root
* * * * * /var/cron/cpu_Perf.sh
$ crontab -l
* * * * * /var/cron/cpu_Perf.sh
保存成功后,每一分钟就会执行一次脚本。
如果服务器关机或者无法运行任务,定时任务就不会执行,服务器恢复后,定时任务不会执行没有执行的定时任务。这种场景下可以使用anacron命令,它与crond功能相同,增加了执行被跳过任务的功能。一旦服务器启动,anacron就会检查配置的定时任务是否错过了上一次执行,如果有,将立即运行这个任务,且只运行一次(不管错过了多少个周期)。
也就是说, anacron 是用来保证由于系统原因导致错过的定时任务可以在系统正常后执行的服务。
可以使用 anacron 命令来管理 anacron 服务,语法格式如下:
anacron [options] [job] ...
anacron -T [-t anacrontab-file]
options选项:
job 是 /etc/anacrontab 文件中定义的工作名 job-identifier
下面来介绍一下anacron的执行过程:
1、根据脚本需要执行的频率,将脚本安装到/etc/cron.[hourly|daily|weekly|monthly] 目录中:
/etc/cron.hourly
/etc/cron.daily
/etc/cron.monthly
/etc/cron.weekly
2、crond 服务会执行/etc/cron.d/0hourly 中指定的cron 任务,
$ cat /etc/cron.d/0hourly
# Run the hourly jobs
SHELL=/bin/bash
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root
01 * * * * root run-parts /etc/cron.hourly
每小时运行一次 run-parts 程序,而 run-parts 程序执行 /etc/cron.hourly 中的所有的shell脚本。
/etc/cron.hourly 目录中包含 0anacron 脚本:
$ ls /etc/cron.hourly
0anacron mcelog.cron
3、 0anacron 脚本通过 /etc/anacrontab 配置文件来运行anacron程序。
$ cat /etc/anacrontab
# /etc/anacrontab: configuration file for anacron
# See anacron(8) and anacrontab(5) for details.
SHELL=/bin/sh
PATH=/sbin:/bin:/usr/sbin:/usr/bin
MAILTO=root
# the maximal random delay added to the base delay of the jobs
RANDOM_DELAY=45
# the jobs will be started during the following hours only
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
/etc/anacrontab 配置文件执行cron.[daily|weekly|monthly] 目录中的可执行文件。
anacron的监测周期为每天、每周和每月,每天执行一次/etc/cron.daily 目录中的程序,每周执行一次 /etc/cron.weekly 中的程序,每月执行一次 /etc/cron.monthly 中的程序。
anacron不能在指定某个时间运行某个程序,它的设计目的是在特定的时间间隔运行某个程序,例如每天,每周日或者每月第一天的03:00运行某个程序。如果因为某种原因(关机或者服务器异常)没有执行,anacron会在服务器正常后运行一次错过的执行。
那么,anacron 是如何判断这些定时任务错过了执行呢?
其实是通过读取上次执行 anacron 的时间记录文件,通过两个时间的差值判断是否超过指定间隔时间(1天、1周和1月)。
/var/spool/anacron/ 目录中的 cron.[daily|weekly|monthly] 文件记录了上一次执行 cron任务 的时间:
$ ls /var/spool/anacron/
cron.daily cron.monthly cron.weekly
$ cat /var/spool/anacron/cron.daily
20211123
前面介绍了在Linux中通常用 crond 服务来实现任务定时执行,在很多场景都会用到定时任务,比如定时提醒,定时发送邮件等。比如Python中可以使用APScheduler库执行定时任务,JAVA可以使用Quartz框架实现,Go语言使用 github.com/robfig/cron 包。
在持续测试平台Jenkins中经常会配置定时执行任务,下面简单介绍一下Jenkins定时构建配置方法。
在配置Jenkins任务时,构建定时任务主要有两种形式:
在【Build Triggers】中选择 Build periodically 或者 Poll SCM
在Schedule中输入cron表达式来配置定时任务。
Jenkins也可以创建多个定时,比如在每个工作日的9:30和每周五22:30构建:
30 9 * * 1-5
30 22 * * 5
--THE END--