1. 简介
crond
是 linux
下用来周期性的执行某种任务或等待处理某些事件的一个守护进程,与windows下的计划任务类似,当安装完成操作系统后,默认会安装此服务 工具,并且会自动启动crond
进程,crond
进程每分钟会定期检查是否有要执行的任务,如果有要执行的任务,则自动执行该任务。
2. crontab命令详解
命令格式
crontab [-u user] file
crontab [-u user] [ -e | -l | -r ]
参数
-u user:
用来设定某个用户的crontab服务,例如,-u ixdba
表示设定ixdba用户的crontab服务file:
file是命令文件的名字,表示将file做为crontab的任务列表文件并载入crontab。如果在命令行中没有指定这个文件,crontab命令将接受标准输入(键盘)上键入的命令,并将它们载入crontabcrontab -e
编辑某个用户的crontab文件内容。如果不指定用户,则表示编辑当前用户的crontab文件crontab -l
显示某个用户的crontab文件内容,如果不指定用户,则表示显示当前用户的crontab文件内容crontab -r
从/var/spool/cron
目录中删除某个用户的crontab文件,如果不指定用户,则默认删除当前用户的crontab文件-i
在删除用户的crontab文件时给确认提示
2. 使用crontab构建定时任务
2.1 构建crontab文件
创建一个文件,此处命名为cronfile
, 在其中加入如下内容:
* * * * * /bin/bash /share_v3/dev/testDir/start.sh >> /share_v3/dev/testDir/nohup_crontab.out
该内容表示每隔一分钟运行一次start.sh
文件,并将crontab执行的日志写入nohup_crontab.out
文件中
如上所示:用户所建立的crontab文件中,每一行都代表一项任务,每行的每个字段代表一项设置,它的格式共分为六个字段,前五段是时间设定段,第六段是要执行的命令段 基本格式如minute hour day month week command
每个字段之间用空格隔开
* | * | * | * | * | command |
---|---|---|---|---|---|
分钟 | 小时 | 几号 | 月份 | 星期几 | 要执行的命令 |
0-59 | 0-23 | 1-31 | 1-12 | 0-6 |
在上面各字段中可以使用如下特殊字符:
*
代表所有可能的值,例如month字段如果是星号,则表示在满足其它字段的制约条件后每月都执行该命令操作
,
可以用逗号隔开的值指定一个列表范围,例如 hour 字段设定成 1,2,7
,表示在满足其它字段的制约条件后每第一个小时,第二个小时第7个小时执行
-
以用整数之间的中杠表示一个整数范围,例如2-6
表示2,3,4,5,6
/
用正斜线指定时间的间隔频率,例如 0-23/2
表示每两小时执行一次。同时正斜线可以和星号一起使用,例如*/10
,如果用在minute字段,表示每十分钟执行一次
2.2 启动crontab服务
执行 crontab confile
命令2.1中设定的定时任务即已启动,等待到规定时间即可执行。
在2.1中我们设定了每隔一分钟执行start.sh
文件,start.sh
文件内容如下:
#!/bin/bash
cur_time=$(date "+%Y%m%d%H%M%S")
save_name="nohup_${cur_time}.out"
save_path="/share_v3/dev/testDir/${save_name}"
nohup /share/apps/anaconda3/envs/spider/bin/python /share_v3/dev/testDir/hello.py > $save_path 2>&1 &
echo "finished....${cur_time}"
即执行hello.py
文件,并将hello.py
日志输出到 save_path
指定的文件中。hello.py
文件内容如下,即每次都写入到文件crontab_run.txt
一个内容
import logging
import sys
sys.path.append("/share_v3/dev/")
LOG_FORMAT = "%(asctime)s %(levelname)s %(message)s"
logging.basicConfig(level=logging.INFO, format=LOG_FORMAT)
import datetime
now = datetime.datetime.now()
with open("/share_v3/dev/testDir/crontab_run.txt", "a", encoding="utf-8") as fw:
fw.write("hello word, current time: %s \n"%now)
print("print:%s\n"%now)
logging.info("write sucess: %s"%now)
等待一定时间后我们可以看到如下结果:
(1) 目录中存在如下日志文件,可以看出每隔一分钟就会输出一个日志文件
(2)查看crontab 执行日志 nohup_crontab.out
(3)查看python程序中写入的文件crontab_run.txt
(4)随机打开一个python程序运行日志文件nohup_20210831210501.out
2.3 删除定时任务
使用crontab -l
查看当前有哪些定时任务
每一行代表一个任务,可以看到此处只有一个任务,使用crontab -e
编辑此任务(删除该条内容即可停止定时任务)
2.4 其他命令
可以在/var/spool/cron/
目录下查看所有用户存放的crontab文件,以用户名命名
2.5 使用实例
# 每1分钟执行一次command
* * * * * command
# 每小时的第3和第15分钟执行
3,15 * * * * command
# 在上午8点到11点的第3和第15分钟执行
3,15 8-11 * * * command
# 每隔两天的上午8点到11点的第3和第15分钟执行
3,15 8-11 */2 * * command
# 每个星期一的上午8点到11点的第3和第15分钟执行
3,15 8-11 * * 1 command
# 每晚的21:30重启smb
30 21 * * * /etc/init.d/smb restart
# 每月1、10、22日的4 : 45重启smb
45 4 1,10,22 * * /etc/init.d/smb restart
# 每周六、周日的1 : 10重启smb
10 1 * * 6,0 /etc/init.d/smb restart
# 每天18 : 00至23 : 00之间每隔30分钟重启smb
0,30 18-23 * * * /etc/init.d/smb restart
# 每星期六的晚上11 : 00 pm重启smb
0 23 * * 6 /etc/init.d/smb restart
# 每一小时重启smb
* */1 * * * /etc/init.d/smb restart
3. 常见问题
1. 在创建cronfile或者直接用crontab -e 创建任务时必须用绝对路径,否则很有可能创建的任务无法运行
可以看到2.1中start.sh中所有路径都用了绝对路径,包括python环境
2. 若要得到输出日志文件必须用 2>&1 &
本文第一次在start.sh
文件中使用如下方法运行python文件,无法得到python文件运行输出的日志
nohup /share/apps/anaconda3/envs/spider/bin/python /share_v3/dev/testDir/hello.py >> $save_path &
后改为2.1中的样子后得到了日志文件,目前尚未弄清楚这是为什么