linux 定时任务(crontab)

网友投稿 907 2022-05-30

简介

crond 是linux下用来周期性的执行某种任务或等待处理某些事件的一个守护进程,与windows下的计划任务类似,当安装完成操作系统后,默认会安装此服务 工具,并且会自动启动crond进程,crond进程每分钟会定期检查是否有要执行的任务,如果有要执行的任务,则自动执行该任务

命令格式

命令格式:crontab [-u username] [-l|-e|-r]

参数:

-u: 只有root才能进行这个任务,也即帮其他用户新建/删除crontab工作调度;

-e: 编辑crontab 的工作内容;

-l: 查阅crontab的工作内容;

-r: 删除所有的crontab的工作内容,若仅要删除一项,请用-e去编辑

查看帮助文档

如果使用 crontab -h 会报错,但也会输出一个简写的帮助文档

正确的查看帮助文档的方法是使用 man crontab

系统的计划任务放在 /etc/crontab,并且里面有计划参数的解析注释 <分钟> <小时> <当月的第几日> <月> <每周的第几天> <定时执行的命令>

周的数字为0或7时,都代表“星期天”的意思。另外,还有一些辅助的字符,大概有下面这些:

编写定时任务

crontab的环境变量在 /etc/crontab 中,与我们系统的环境变量不同,因此所有文件都要用绝对路径。用相对路径不能正常执行。

下面以每分钟执行一次为例

定时执行计划

cron.crontab

* * * * * echo `date '+\%F \%T' > /home/chen/output.txt`

1

定时执行脚本

不包含变量

shell1.crontab

*/1 * * * * /home/chen/test1.sh`

1

test1.sh

#!/bin/bash #!/bin/bash echo test >> /home/chen/output.txt

1

2

3

包含变量

shell2.crontab

*/1 * * * * /home/chen/test1.sh >> /home/chen/output.txt

1

test2.sh

#!/bin/bash start_time=`date -d '-1 minute' '+%F %T'` end_time=`date '+%F %T'` echo ${start_time} ${end_time}

1

2

3

4

定时执行python脚本

python控制台重定向到文件

py1.crontab

* * * * * /usr/bin/python home/chen/print.py >> /home/chen/output.txt

1

print.py

#!/usr/bin/python # -*- coding: UTF-8 -*- import datetime now_time = datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S") before_time = (datetime.datetime.now()+datetime.timedelta(minutes=-1)).strftime("%Y-%m-%d %H:%M:%S"); print before_time, now_time

linux 定时任务(crontab)

1

2

3

4

5

6

7

8

python直接写入文件

py2.crontab

* * * * * python home/chen/file.py

1

file.py

#!/usr/bin/python # -*- coding: UTF-8 -*- import datetime now_time = datetime.datetime.now().strftime("%Y-%m-%d %H:%M:%S") before_time = (datetime.datetime.now()+datetime.timedelta(minutes=-1)).strftime("%Y-%m-%d %H:%M:%S"); #print before_time, now_time f = open('/home/chen/output.txt', 'a'); f.write(before_time + ' &' + now_time + '\n') f.close();

1

2

3

4

5

6

7

8

9

10

11

常用命令

执行定时任务 crontab <脚本路径> 命令执行计划,例如 crontab task1.crontab

列出当前任务 cronta -l

编辑当前任务 crontab -e

删除所有任务 crontab -r

注意事项

在自定义的 crontab 文件 和 crontab -e 的定时任务编辑器中,可以定义变量

统一时刻,只能执行一个定时任务。当运行新的任务时,之前的任务会被自动取消

定时计划可以用批处理文件,例如:* * * * * <批处理文件的完整路径>。一定要用完整路径,而非相对路径!!!

定时任务的百分号%前面一定要加一个转义符号\,如果不加会被当做换行符,而不是命令

任务计划中可以定义变量<变量名>=<变量值>。但是“变量值”只能是常量,不能引用其他变量。例如end_time=${date '+%F %T'} 会被当做字符串原样输出,无法达到预期效果。如果要定义这种变量,建议换至shell文件中。

如果定时任务没有任何反应,一定是计划文件中的语法有误

由于定时任务都是在后台执行的,因此没有回显,可以通过重定向到文件,判断其是否执行成功。另外,通过 tail -f <文件绝对路径> 持续输出

查看日志

编辑配置文件 sudo vim /etc/rsyslog.d/50-default.conf

将cron前面的注释符去掉 cron.* /var/log/cron.log。

保存文件时用 : w ! sudo tee %

tee 用于读取输入文件,同时保存。%表示当前编辑文件。

注意:该方法要求当前编辑用户必须在 sudoers这个文件中,这也是执行sudo命令的要求。

之后重启 rsyslog 和 cron

sudo service rsyslog restart sudo service cron restart

1

2

后面执行 cat /var/log/cron.log 即可查看后续日志了

查看日志可以发现,每当启用一个定时任务,之前的就被替换了(即同一时刻只能存在一个定时任务)

发现报错:(CRON) info (No MTA installed, discarding output)

原因有两个:

命令中含有shell指令

执行任务过程中会往屏幕输出内容

报错原因:报错的主要原因是没有配置邮件服务器

解决办法:安装并重新配置邮件服务器

sudo apt-get install postfix sudo dpkg-reconfigure postfix

1

2

MAIL (mailed 26 bytes of output but got status 0x004b from MTA#012)

查看日志 tail -f /var/log/cron.log,发现报错

由于是邮件错误,因此查看邮件日志 tail /var/log/mail.log。错误如下:fatal: open /etc/postfix/main.cf: No such file or directory

执行 sudo dpkg-reconfigure postfix 命令,在配置项里面选择除了第1项以外的(我是选第2项)

Linux

版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。

上一篇:Python:数据提取之JSON与JsonPATH
下一篇:疯狂JAVA之学习笔记(6)------------标识符和关键字
相关文章