搜索
首页系统教程LINUXLinux下的crontab出现的问题和解决问题的解决办法

<pre style="letter-spacing: 0.544px;font-size: 16px;text-align: left"><p><img   style="max-width:90%" src="/uploads/20240213/170783644765cb841f5e758.jpg" alt="linux计划任务格式_linux计划任务整点执行_linux任务计划不生效"></p><p style="letter-spacing: 0.544px"><img   style="max-width:90%" src="/uploads/20240213/170783645065cb842225c8f.jpg" alt="linux计划任务整点执行_linux计划任务格式_linux任务计划不生效"><strong data-filtered="filtered" style="letter-spacing: 0.544px;text-align: center;font-family: 微软雅黑;font-size: 15px"></strong></p><pre style="letter-spacing: 0.544px"><pre style="letter-spacing: 0.544px"><p><strong data-filtered="filtered" style="font-family: 微软雅黑;font-size: 15px;letter-spacing: 0.544px"></strong><strong data-filtered="filtered" style="font-family: 微软雅黑;font-size: 15px;letter-spacing: 0.544px"></strong></p><pre style="letter-spacing: 0.544px"><pre style="letter-spacing: 0.544px"><p><span style="font-family: 微软雅黑;letter-spacing: 0.544px;text-decoration: underline;font-size: 15px"><strong>免费加入嵌入式项目实战群(送开发板),</strong></span></p><p><span style="font-size: 15px;font-family: 微软雅黑;letter-spacing: 0.544px;text-decoration: underline"><strong>请加良许微信:coderliangxu-8</strong></span></p>

<pre style="letter-spacing: 0.544px"><pre style="line-height: 25.6px;letter-spacing: 0.544px;min-height: 1em"><h1style><section style="line-height: 25.6px;letter-spacing: 0.544px;min-height: 1em"><section style="line-height: 25.6px;letter-spacing: 0.544px;min-height: 1em"><section style="line-height: 25.6px;letter-spacing: 0.544px;min-height: 1em"><section style="line-height: 25.6px;letter-spacing: 0.544px;min-height: 1em"><section style="line-height: 25.6px;letter-spacing: 0.544px;min-height: 1em"><section style="line-height: 25.6px;letter-spacing: 0.544px;min-height: 1em"><blockquote style="font-size: 16px;line-height: 25.6px;letter-spacing: 0.544px;min-height: 1em"><section data-mpa-template="t" style="line-height: 25.6px;letter-spacing: 0.544px;min-height: 1em"><section data-mpa-template="t" style="line-height: 25.6px;letter-spacing: 0.544px;min-height: 1em"><section data-mpa-template="t" style="line-height: 25.6px;letter-spacing: 0.544px;min-height: 1em"><section data-mpa-template="t" style="line-height: 25.6px;letter-spacing: 0.544px;min-height: 1em"><section data-mpa-template="t" style="line-height: 25.6px;letter-spacing: 0.544px;min-height: 1em"><section data-mpa-template="t" style="line-height: 25.6px;letter-spacing: 0.544px;min-height: 1em"><section data-mpa-template="t" style="line-height: 25.6px;letter-spacing: 0.544px;min-height: 1em"><section data-mpa-template="t" style="line-height: 25.6px;letter-spacing: 0.544px;min-height: 1em"><section data-mpa-template="t" style="line-height: 25.6px;letter-spacing: 0.544px;min-height: 1em"><section data-mpa-template="t" style="line-height: 25.6px;letter-spacing: 0.544px;min-height: 1em"><section data-mpa-template="t" style="line-height: 25.6px;letter-spacing: 0.544px;min-height: 1em"><section style="line-height: 25.6px;letter-spacing: 0.544px;min-height: 1em"><span style="font-family: 微软雅黑;letter-spacing: 0.544px;text-align: center;font-size: 15px"><p style="line-height: 25.6px;letter-spacing: 0.544px;font-size: 16px;text-align: left"><span style="font-size: 12px;letter-spacing: 0.544px;text-align: center">来源:运维漫谈</span><span></span></p></span></section></section></section></section></section></section></section></section></section></section></section></section></blockquote></section></section></section></section></section></section></h1style>

实际工作中,crontab出现的问题是多种多样的,下边就深入介绍下crontab在具体工作中容易出现的问题和解决问题的办法。

一、crontab能干啥

crond是linux下拿来周期性的执行某种任务或等待处理个别风波的一个守护进程,与windows下的计划任务类似,当安装完成操作系统后,默认会安装此服务工具,而且会手动启动crond进程,crond进程每分钟会定期检测是否有要执行的任务,假如有要执行的任务,则手动执行该任务。

Linux下的任务调度分为两类,系统任务调度和用户任务调度。

关于crontab的用途,在企业实际应用中十分广泛,常见的有定时数据备份、定时系统检查、定时数据搜集、定时更新配置、定时生成报表等等。

二、crontab应用实例

1、crontab使用格式

crontab常用的使用格式有如下两种:

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px"><span style="border-width: 0px;border-style: initial;border-color: initial">crontab</span> <span style="border-width: 0px;border-style: initial;border-color: initial">[-u user]</span> <span style="border-width: 0px;border-style: initial;border-color: initial">[file]</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">crontab</span> <span style="border-width: 0px;border-style: initial;border-color: initial">[-u user]</span> <span style="border-width: 0px;border-style: initial;border-color: initial">[-e|-l|-r |-i]</span></span></code>

选项涵义如下:

2、crontab文件句型

用户所构建的crontab文件中,每一行都代表一项任务,每行的每位数组代表一项设置,它的格式共分为六个数组,前五段是时间设定段,第六段是要执行的命令段,格式如下:

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px">minute hour day month week <span style="border-width: 0px;border-style: initial;border-color: initial">command</span></span></code>

其中:

?minute:表示分钟,可以是从0到59之间的任何整数。

?hour:表示小时,可以是从0到23之间的任何整数。

?day:表示日期,可以是从1到31之间的任何整数。

?month:表示月份,可以是从1到12之间的任何整数。

?week:表示礼拜几,可以是从0到7之间的任何整数,这儿的0或7代表礼拜日。

?command:要执行的命令,可以是系统命令,也可以是自己编撰的脚本文件。

在以上各个数组中,还可以使用以下特殊字符:

?星号():代表所有可能的值,比如month数组若果是星号,则表示在满足其它数组的阻碍条件后每月都执行该命令操作。

?冒号(,):可以用冒号隔开的值指定一个列表范围,比如,“1,2,5,7,8,9”

?中杠(-):可以用整数之间的中杠表示一个整数范围,比如“2-6”表示“2,3,4,5,6”

?正斜线(/):可以用正斜线指定时间的间隔频度,比如“0-23/2”表示每两小时执行一次。同时正斜线可以和星号一起使用,比如/10,假如用在minute数组,表示每十分钟执行一次。

3、几个crontab事例

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px">0 /3 /usr/<span style="border-width: 0px;border-style: initial;border-color: initial">local</span>/apache2/apachectl restart</span></code>

表示每隔3个小时重启apache服务一次。

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px"><span style="border-width: 0px;border-style: initial;border-color: initial">30</span> <span style="border-width: 0px;border-style: initial;border-color: initial">3</span> <span style="border-width: 0px;border-style: initial;border-color: initial">6</span> <span style="border-width: 0px;border-style: initial;border-color: initial">/webdata/bin/backup.sh</span></span></code>

表示每周六的3点30分执行/webdata/bin/backup.sh脚本的操作。

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px"><span style="border-width: 0px;border-style: initial;border-color: initial">0</span> <span style="border-width: 0px;border-style: initial;border-color: initial">0</span> <span style="border-width: 0px;border-style: initial;border-color: initial">1</span><span style="border-width: 0px;border-style: initial;border-color: initial">,20</span> <span style="border-width: 0px;border-style: initial;border-color: initial">fsck</span> <span style="border-width: 0px;border-style: initial;border-color: initial">/dev/sdb8</span></span></code>

表示每位月的1号和20号检测/dev/sdb8c盘设备。

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px">10 5 /5 * <span style="border-width: 0px;border-style: initial;border-color: initial">echo</span> <span style="border-width: 0px;border-style: initial;border-color: initial">""</span>>/usr/<span style="border-width: 0px;border-style: initial;border-color: initial">local</span>/apache2/<span style="border-width: 0px;border-style: initial;border-color: initial">log</span>/access_log</span></code>

表示每位月的5号、10号、15号、20号、25号、30号的5点10分执行清除apache日志操作。

三、系统级任务调度/etc/crontab

在/etc目录下有一个crontab文件,这个就是系统任务调度的配置文件。

/etc/crontab文件包括下边几行:

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px"><span style="border-width: 0px;border-style: initial;border-color: initial">SHELL=/bin/bash</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">PATH=/sbin:/bin:/usr/sbin:/usr/bin</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">MAILTO=root</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">HOME=/</span><br><span style="border-width: 0px;border-style: initial;border-color: initial"># run-parts</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">01</span> <span style="border-width: 0px;border-style: initial;border-color: initial">*</span> <span style="border-width: 0px;border-style: initial;border-color: initial">*</span> <span style="border-width: 0px;border-style: initial;border-color: initial">*</span> <span style="border-width: 0px;border-style: initial;border-color: initial">*</span> <span style="border-width: 0px;border-style: initial;border-color: initial">root</span> <span style="border-width: 0px;border-style: initial;border-color: initial">run-parts</span> <span style="border-width: 0px;border-style: initial;border-color: initial">/etc/cron.hourly</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">02</span> <span style="border-width: 0px;border-style: initial;border-color: initial">4</span> <span style="border-width: 0px;border-style: initial;border-color: initial">*</span> <span style="border-width: 0px;border-style: initial;border-color: initial">*</span> <span style="border-width: 0px;border-style: initial;border-color: initial">*</span> <span style="border-width: 0px;border-style: initial;border-color: initial">root</span> <span style="border-width: 0px;border-style: initial;border-color: initial">run-parts</span> <span style="border-width: 0px;border-style: initial;border-color: initial">/etc/cron.daily</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">22</span> <span style="border-width: 0px;border-style: initial;border-color: initial">4</span> <span style="border-width: 0px;border-style: initial;border-color: initial">*</span> <span style="border-width: 0px;border-style: initial;border-color: initial">*</span> <span style="border-width: 0px;border-style: initial;border-color: initial">0</span> <span style="border-width: 0px;border-style: initial;border-color: initial">root</span> <span style="border-width: 0px;border-style: initial;border-color: initial">run-parts</span> <span style="border-width: 0px;border-style: initial;border-color: initial">/etc/cron.weekly</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">42</span> <span style="border-width: 0px;border-style: initial;border-color: initial">4</span> <span style="border-width: 0px;border-style: initial;border-color: initial">1</span> <span style="border-width: 0px;border-style: initial;border-color: initial">*</span> <span style="border-width: 0px;border-style: initial;border-color: initial">*</span> <span style="border-width: 0px;border-style: initial;border-color: initial">root</span> <span style="border-width: 0px;border-style: initial;border-color: initial">run-parts</span> <span style="border-width: 0px;border-style: initial;border-color: initial">/etc/cron.monthly</span></span></code>

从前面的示例文件可看出,crontab的任务列表主要由两部份组成:环境变量配置与定时任务配置。可能你们在工作中更多是只用到了任务配置部份。

前四行是拿来配置crond任务运行的环境变量,第一行SHELL变量指定了系统要使用那个shell,这儿是bash,第二行PATH变量指定了系统执行命令的路径,第三行MAILTO变量指定了crond的任务执行信息将通过电子短信发送给root用户,假如MAILTO变量的值为空,则表示不发送任务执行信息给用户linux视频,第四行的HOME变量指定了在执行命令或则脚本时使用的主目录。第六至九行就是crontab执行格式的具体写法。

四、crontab调试解析利器

一般在使用crontab添加任务时,我们会借助自己已有知识编撰定时句子。当须要测试句子是否正确时,还须要在服务器上不断调试,,这些方法太不高效了。有没有一款工具,只要我们给出词句,能够告诉具体执行时间以及对错呢?还真有,下边介绍一款鬼佬开发的crontab在线解析工具。

工具地址:

linux任务计划不生效_linux计划任务格式_linux计划任务整点执行

给出这个工具的截图如下:

linux任务计划不生效_linux计划任务整点执行_linux计划任务格式

好用不好用,你试试就晓得。

五、crontab使用的各类坑

1、环境变量问题

当我们刚使用crontab时,运维老手们通常会告知所有命令尽量都使用绝对路径,以防错误。这是为何?这就和我们下边要谈的环境变量有关了。

首先,获取shell终端环境变量,内容如下:

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px"><span style="border-width: 0px;border-style: initial;border-color: initial">[root@SparkWorker1 dylogs]</span><span style="border-width: 0px;border-style: initial;border-color: initial"># env</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">XDG_SESSION_ID</span>=<span style="border-width: 0px;border-style: initial;border-color: initial">1629</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">HOSTNAME</span>=SparkWorker1<br><span style="border-width: 0px;border-style: initial;border-color: initial">TERM</span>=linux<br><span style="border-width: 0px;border-style: initial;border-color: initial">SHELL</span>=/bin/bash<br><span style="border-width: 0px;border-style: initial;border-color: initial">HISTSIZE</span>=<span style="border-width: 0px;border-style: initial;border-color: initial">1000</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">SSH_CLIENT</span>=<span style="border-width: 0px;border-style: initial;border-color: initial">172.16</span>.<span style="border-width: 0px;border-style: initial;border-color: initial">213.132</span> <span style="border-width: 0px;border-style: initial;border-color: initial">50080</span> <span style="border-width: 0px;border-style: initial;border-color: initial">22</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">HADOOP_PREFIX</span>=/opt/hadoop/current<br><span style="border-width: 0px;border-style: initial;border-color: initial">CATALINA_BASE</span>=/opt/hadoop/current/share/hadoop/httpfs/tomcat<br><span style="border-width: 0px;border-style: initial;border-color: initial">SSH_TTY</span>=/dev/pts/<span style="border-width: 0px;border-style: initial;border-color: initial">1</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">QT_GRAPHICSSYSTEM_CHECKED</span>=<span style="border-width: 0px;border-style: initial;border-color: initial">1</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">USER</span>=root<br><span style="border-width: 0px;border-style: initial;border-color: initial">MAIL</span>=/var/spool/mail/root<br><span style="border-width: 0px;border-style: initial;border-color: initial">PATH</span>=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/usr/java/default/bin:/opt/hadoop/current/bin:/opt/hadoop/current/sbin:/root/bin<br><span style="border-width: 0px;border-style: initial;border-color: initial">PWD</span>=/data/dylogs<br><span style="border-width: 0px;border-style: initial;border-color: initial">LANG</span>=zh_CN.UTF-<span style="border-width: 0px;border-style: initial;border-color: initial">8</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">HOME</span>=/root</span></code>

要获取crontab环境变量信息,可以设置如下计划任务:

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px"><span style="border-width: 0px;border-style: initial;border-color: initial">* </span><span style="border-width: 0px;border-style: initial;border-color: initial">* *</span> <span style="border-width: 0px;border-style: initial;border-color: initial">* *</span> /usr/bin/env > /tmp/env.txt</span></code>

等待片刻,env.txt输出内容如下:

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px"><span style="border-width: 0px;border-style: initial;border-color: initial">[root@SparkWorker1 dylogs]</span><span style="border-width: 0px;border-style: initial;border-color: initial"># cat /tmp/env.txt</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">XDG_SESSION_ID</span>=<span style="border-width: 0px;border-style: initial;border-color: initial">1729</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">SHELL</span>=/bin/sh<br><span style="border-width: 0px;border-style: initial;border-color: initial">USER</span>=root<br><span style="border-width: 0px;border-style: initial;border-color: initial">PATH</span>=/usr/bin:/bin<br><span style="border-width: 0px;border-style: initial;border-color: initial">PWD</span>=/root<br><span style="border-width: 0px;border-style: initial;border-color: initial">LANG</span>=zh_CN.UTF-<span style="border-width: 0px;border-style: initial;border-color: initial">8</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">SHLVL</span>=<span style="border-width: 0px;border-style: initial;border-color: initial">1</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">HOME</span>=/root<br><span style="border-width: 0px;border-style: initial;border-color: initial">LOGNAME</span>=root<br><span style="border-width: 0px;border-style: initial;border-color: initial">XDG_RUNTIME_DIR</span>=/run/user/<span style="border-width: 0px;border-style: initial;border-color: initial">0</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">_</span>=/usr/bin/env</span></code>

从里面输出结果可知,shell命令行的PATH值为

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px">PATH=<span style="border-width: 0px;border-style: initial;border-color: initial">/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/usr/java/default/bin:/opt/hadoop/current/bin:/opt/hadoop/current/sbin:/root/bin</span></span></code>

而crontab中的PATH值为:

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px">PATH=<span style="border-width: 0px;border-style: initial;border-color: initial">/usr/bin:/bin</span></span></code>

对比crontab环境变量与shell终端环境变量的输出,可以发觉二者的差别很大。你们可能碰到过,在shell命令行执行脚本都没有问题,而放在crontab后却执行异常,或则执行失败,此时,我们就须要考虑是否命令涉及的环境变量在crontab和shell命令行间存在差别。

比如,我们在crontab中执行了如下定时任务:

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px"><span style="border-width: 0px;border-style: initial;border-color: initial">20</span> <span style="border-width: 0px;border-style: initial;border-color: initial">16</span> <span style="border-width: 0px;border-style: initial;border-color: initial">*</span> <span style="border-width: 0px;border-style: initial;border-color: initial">*</span> <span style="border-width: 0px;border-style: initial;border-color: initial">*</span> <span style="border-width: 0px;border-style: initial;border-color: initial">php</span> <span style="border-width: 0px;border-style: initial;border-color: initial">autosave.php</span></span></code>

而假如我们的php是安装在/usr/local/bin/目录下的话,这么前面这个定时任务因为未能找到php命令,会运行失败。

这么,晓得了环境变量问题,可能造成计划任务未能正常执行,如何能够避开这个问题呢,这个交给你们一个终极大招,可以在crontab中加入如下配置,保证你的计划任务执行不会出现环境变量问题:

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px">* * * * * <span style="border-width: 0px;border-style: initial;border-color: initial">source</span> /<span style="border-width: 0px;border-style: initial;border-color: initial">$HOME</span>/.bash_profile && <span style="border-width: 0px;border-style: initial;border-color: initial">command</span></span></code>

linux计划任务整点执行_linux计划任务格式_linux任务计划不生效

这个似乎是在执行计划任务命令之前,先加载了用户环境变量信息,由此可保证所有环境变量都可正常加载。

2、定时时间配置误区

时间是crontab的核心,稍稍配置不当,才会出现问题,先看在整点时间设置时可能出现的错误,比如,设定每晚2点执行一次任务,好多同学可能如此写过:

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px"><span style="border-width: 0px;border-style: initial;border-color: initial">* </span>2 <span style="border-width: 0px;border-style: initial;border-color: initial">* *</span> * command</span></code>

很显著linux计划任务整点执行linux 删除文件夹,这个时间写法是错误的,当我们看到每晚2点执行一次某任务时,好多人会把重点放到2点,而忽视了执行一次的需求。前面这个定时任务他会在2点开始执行,每分钟执行一次,总共执行60次。

正确的写法应当是这样的:

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px"><span style="border-width: 0px;border-style: initial;border-color: initial">0</span> <span style="border-width: 0px;border-style: initial;border-color: initial">2</span> <span style="border-width: 0px;border-style: initial;border-color: initial">*</span> <span style="border-width: 0px;border-style: initial;border-color: initial">*</span> <span style="border-width: 0px;border-style: initial;border-color: initial">*</span> <span style="border-width: 0px;border-style: initial;border-color: initial">command</span></span></code>

这个才表示每晚2点0分执行command对应的任务。

3、特殊符号%问题

%在crontab中是特殊符号,具体涵义如下:

第一个%表示标准输入的开始,其余%表示换行符,看下边两个反例:

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px"><span style="border-width: 0px;border-style: initial;border-color: initial">* </span><span style="border-width: 0px;border-style: initial;border-color: initial">* *</span> <span style="border-width: 0px;border-style: initial;border-color: initial">* *</span> cat >> /tmp/cat.txt 2>&1 % stdin out</span></code>

查看/tmp/cat.txt的内容为:

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px"><span style="border-width: 0px;border-style: initial;border-color: initial">stdin</span> out</span></code>

再看下边这个事例:

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px"><span style="border-width: 0px;border-style: initial;border-color: initial">*</span> <span style="border-width: 0px;border-style: initial;border-color: initial">*</span> <span style="border-width: 0px;border-style: initial;border-color: initial">*</span> <span style="border-width: 0px;border-style: initial;border-color: initial">*</span> <span style="border-width: 0px;border-style: initial;border-color: initial">*</span> <span style="border-width: 0px;border-style: initial;border-color: initial">cat</span> <span style="border-width: 0px;border-style: initial;border-color: initial">>></span> <span style="border-width: 0px;border-style: initial;border-color: initial">/tmp/cat1.txt</span> <span style="border-width: 0px;border-style: initial;border-color: initial">2</span><span style="border-width: 0px;border-style: initial;border-color: initial">>&1</span> <span style="border-width: 0px;border-style: initial;border-color: initial">%</span> <span style="border-width: 0px;border-style: initial;border-color: initial">stdin</span> <span style="border-width: 0px;border-style: initial;border-color: initial">out</span> <span style="border-width: 0px;border-style: initial;border-color: initial">1</span> <span style="border-width: 0px;border-style: initial;border-color: initial">%</span> <span style="border-width: 0px;border-style: initial;border-color: initial">stdin</span> <span style="border-width: 0px;border-style: initial;border-color: initial">out</span> <span style="border-width: 0px;border-style: initial;border-color: initial">2</span> <span style="border-width: 0px;border-style: initial;border-color: initial">%</span> <span style="border-width: 0px;border-style: initial;border-color: initial">stdin</span> <span style="border-width: 0px;border-style: initial;border-color: initial">out</span> <span style="border-width: 0px;border-style: initial;border-color: initial">3</span></span></code>

查看/tmp/cat1.txt的内容如下:

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px"><span style="border-width: 0px;border-style: initial;border-color: initial">stdin</span> out <span style="border-width: 0px;border-style: initial;border-color: initial">1</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">stdin</span> out <span style="border-width: 0px;border-style: initial;border-color: initial">2</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">stdin</span> out <span style="border-width: 0px;border-style: initial;border-color: initial">3</span></span></code>

有输出内容可知,第一个%表示标准输入的开始,其余%表示换行符。

既然"%"是特殊字符,这么在crontab中使用时,就要非常注意,如何使用这种特殊字符呢,很显著,使用转移字符即可linux计划任务整点执行,比如:

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px"><span style="border-width: 0px;border-style: initial;border-color: initial">* </span><span style="border-width: 0px;border-style: initial;border-color: initial">* *</span> <span style="border-width: 0px;border-style: initial;border-color: initial">* *</span> cat >> /tmp/cat2.txt 2>&1 % Special character escape %.</span></code>

查看输出/tmp/cat2.txt输出内容如下:

linux任务计划不生效_linux计划任务整点执行_linux计划任务格式

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px">Special character <span style="border-width: 0px;border-style: initial;border-color: initial">escape</span> %.</span></code>

可以看见,执行成功了,并成功避免这个坑了。

4、关于crontab的输出重定向

在crontab执行的计划任务中,有些任务若果不做输出重定向,这么本来会输出到屏幕的信息,会以短信的方式输出到某个文件中,比如,执行下边这个计划任务:

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px"><span style="border-width: 0px;border-style: initial;border-color: initial">* </span><span style="border-width: 0px;border-style: initial;border-color: initial">* *</span> <span style="border-width: 0px;border-style: initial;border-color: initial">* *</span> /bin/date</span></code>

这个计划任务是没有做输出重定向的,他的主要用途是输出时间,因为没有配置输出重定向,这么这个时间信息默认将以短信的方式输出到/var/spool/mail/$USER(这个$USER对应的是系统用户,这儿是root用户)文件中,大致内容如下:

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px"><span style="border-width: 0px;border-style: initial;border-color: initial">From</span> <span style="border-width: 0px;border-style: initial;border-color: initial">[email protected]</span> <span style="border-width: 0px;border-style: initial;border-color: initial">Fri</span> <span style="border-width: 0px;border-style: initial;border-color: initial">Sep</span> <span style="border-width: 0px;border-style: initial;border-color: initial">21</span> <span style="border-width: 0px;border-style: initial;border-color: initial">12</span><span style="border-width: 0px;border-style: initial;border-color: initial">:58:02</span> <span style="border-width: 0px;border-style: initial;border-color: initial">2022</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">Return-Path:</span> <span style="border-width: 0px;border-style: initial;border-color: initial"></span><br><span style="border-width: 0px;border-style: initial;border-color: initial">X-Original-To:</span> <span style="border-width: 0px;border-style: initial;border-color: initial">root</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">Delivered-To:</span> <span style="border-width: 0px;border-style: initial;border-color: initial">[email protected]</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">Received:</span> <span style="border-width: 0px;border-style: initial;border-color: initial">by</span> <span style="border-width: 0px;border-style: initial;border-color: initial">SparkWorker1.localdomain</span> <span style="border-width: 0px;border-style: initial;border-color: initial">(Postfix,</span> <span style="border-width: 0px;border-style: initial;border-color: initial">from</span> <span style="border-width: 0px;border-style: initial;border-color: initial">userid</span> <span style="border-width: 0px;border-style: initial;border-color: initial">0</span><span style="border-width: 0px;border-style: initial;border-color: initial">)</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">id</span> <span style="border-width: 0px;border-style: initial;border-color: initial">F2745192AE;</span> <span style="border-width: 0px;border-style: initial;border-color: initial">Fri,</span> <span style="border-width: 0px;border-style: initial;border-color: initial">21</span> <span style="border-width: 0px;border-style: initial;border-color: initial">Sep</span> <span style="border-width: 0px;border-style: initial;border-color: initial">2022</span> <span style="border-width: 0px;border-style: initial;border-color: initial">12</span><span style="border-width: 0px;border-style: initial;border-color: initial">:58:01</span> <span style="border-width: 0px;border-style: initial;border-color: initial">+0800</span> <span style="border-width: 0px;border-style: initial;border-color: initial">(CST)</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">From:</span> <span style="border-width: 0px;border-style: initial;border-color: initial">"(Cron Daemon)"</span> <span style="border-width: 0px;border-style: initial;border-color: initial"></span><br><span style="border-width: 0px;border-style: initial;border-color: initial">To:</span> <span style="border-width: 0px;border-style: initial;border-color: initial">[email protected]</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">Subject:</span> <span style="border-width: 0px;border-style: initial;border-color: initial">Cron</span> <span style="border-width: 0px;border-style: initial;border-color: initial"></span> <span style="border-width: 0px;border-style: initial;border-color: initial">/bin/date</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">Content-Type:</span> <span style="border-width: 0px;border-style: initial;border-color: initial">text/plain;</span> <span style="border-width: 0px;border-style: initial;border-color: initial">charset=UTF-8</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">Auto-Submitted:</span> <span style="border-width: 0px;border-style: initial;border-color: initial">auto-generated</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">Precedence:</span> <span style="border-width: 0px;border-style: initial;border-color: initial">bulk</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">X-Cron-Env:</span> <span style="border-width: 0px;border-style: initial;border-color: initial"></span><br><span style="border-width: 0px;border-style: initial;border-color: initial">X-Cron-Env:</span> <span style="border-width: 0px;border-style: initial;border-color: initial"></span><br><span style="border-width: 0px;border-style: initial;border-color: initial">X-Cron-Env:</span> <span style="border-width: 0px;border-style: initial;border-color: initial"></span><br><span style="border-width: 0px;border-style: initial;border-color: initial">X-Cron-Env:</span> <span style="border-width: 0px;border-style: initial;border-color: initial"></span><br><span style="border-width: 0px;border-style: initial;border-color: initial">X-Cron-Env:</span> <span style="border-width: 0px;border-style: initial;border-color: initial"></span><br><span style="border-width: 0px;border-style: initial;border-color: initial">X-Cron-Env:</span> <span style="border-width: 0px;border-style: initial;border-color: initial"></span><br><span style="border-width: 0px;border-style: initial;border-color: initial">X-Cron-Env:</span> <span style="border-width: 0px;border-style: initial;border-color: initial"></span><br><span style="border-width: 0px;border-style: initial;border-color: initial">X-Cron-Env:</span> <span style="border-width: 0px;border-style: initial;border-color: initial"></span><br><span style="border-width: 0px;border-style: initial;border-color: initial">Message-Id:</span> <span style="border-width: 0px;border-style: initial;border-color: initial"></span><br><span style="border-width: 0px;border-style: initial;border-color: initial">Date:</span> <span style="border-width: 0px;border-style: initial;border-color: initial">Fri,</span> <span style="border-width: 0px;border-style: initial;border-color: initial">21</span> <span style="border-width: 0px;border-style: initial;border-color: initial">Sep</span> <span style="border-width: 0px;border-style: initial;border-color: initial">2022</span> <span style="border-width: 0px;border-style: initial;border-color: initial">12</span><span style="border-width: 0px;border-style: initial;border-color: initial">:58:01</span> <span style="border-width: 0px;border-style: initial;border-color: initial">+0800</span> <span style="border-width: 0px;border-style: initial;border-color: initial">(CST)</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">2022</span><span style="border-width: 0px;border-style: initial;border-color: initial">年</span> <span style="border-width: 0px;border-style: initial;border-color: initial">09</span><span style="border-width: 0px;border-style: initial;border-color: initial">月</span> <span style="border-width: 0px;border-style: initial;border-color: initial">21</span><span style="border-width: 0px;border-style: initial;border-color: initial">日</span> <span style="border-width: 0px;border-style: initial;border-color: initial">星期五</span> <span style="border-width: 0px;border-style: initial;border-color: initial">12</span><span style="border-width: 0px;border-style: initial;border-color: initial">:58:01</span> <span style="border-width: 0px;border-style: initial;border-color: initial">CST</span></span></code>

由此可见,输出内容还是好多的,如遇见任务有大量输出的话,会占用大量c盘空间,其实,这个电邮输出最好关掉,如何关掉呢,只需设置MAILTO环境变量为空即可,里面的计划任务,可做如下更改:

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px">MAILTO=""<br><span style="border-width: 0px;border-style: initial;border-color: initial">* </span><span style="border-width: 0px;border-style: initial;border-color: initial">* *</span> <span style="border-width: 0px;border-style: initial;border-color: initial">* *</span> /bin/date</span></code>

这样,就不会发短信信息到/var/spool/mail/$USER下了,而且问题并没有彻底解决,关掉mail功能后,输出内容将继续写入到/var/spool/clientmqueue中,常年下去,可能占满分区的inode资源,造成任务未能执行。

为了防止这种问题发生,建议任务都加上输出重定向,比如,可以在crontab文件中设置如下方式,忽视日志输出:

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px"><span style="border-width: 0px;border-style: initial;border-color: initial">0</span> *<span style="border-width: 0px;border-style: initial;border-color: initial">/3 * * * /u</span>sr/local/apache2/apachectl restart ><span style="border-width: 0px;border-style: initial;border-color: initial">/dev/</span><span style="border-width: 0px;border-style: initial;border-color: initial">null</span> <span style="border-width: 0px;border-style: initial;border-color: initial">2</span>>&<span style="border-width: 0px;border-style: initial;border-color: initial">1</span></span></code>

其中,“/dev/null2>&1”表示先将标准输出重定向到/dev/null,之后将标准错误重定向到标准输出,因为标准输出早已重定向到了/dev/null,因而标准错误也会重定向到/dev/null,这样日志输出问题就解决了。

5、调试crontab问题的通常思路

要解决crontab相关异常问题,可根据如下思路进行调试:

(1)、通过/var/log/cron日志确认任务是否执行

(2)、如未执行则剖析定时句子,是否是环境变量问题、特殊字符问题、时间配置问题、权限问题等。

(3)、确认crond服务开启,假如定时句子也正确,检测crond服务是否开启。

Systemd形式(centos7及以上)

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px">[root@SparkWorker1 spool]<span style="border-width: 0px;border-style: initial;border-color: initial"># systemctl status crond.service</span></span></code>

SysVinit形式(centos7以下)

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px">[root@SparkWorker1 spool]<span style="border-width: 0px;border-style: initial;border-color: initial"># service crond status</span></span></code>

(4)确认定时任务中命令是否执行成功

这个问题可通过输出获取错误信息进行调试,技巧就是借助重定向获取输出,之后进行剖析。举例如下:

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px"><span style="border-width: 0px;border-style: initial;border-color: initial">* </span><span style="border-width: 0px;border-style: initial;border-color: initial">* *</span> <span style="border-width: 0px;border-style: initial;border-color: initial">* *</span> python /usr/local/dyserver/dypos.py >> /tmp/dypos.log 2>&1</span></code>

通过加上“/tmp/dypos.log2>&1”,就可以很快定位问题,由于这个dypos.py脚本在执行的时侯会把错误信息都输出到dypos.log中,接着查看dypos.log文件,问题一目了然:

<code style="font-family: inherit;font-size: 14px;border-width: 0px;border-style: initial;border-color: initial;line-height: 24px"><span style="font-size: 15px">[root@SparkWorker1 spool]<span style="border-width: 0px;border-style: initial;border-color: initial"># cat /tmp/dypos.log</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">/bin/sh: python: 未找到命令</span><br><span style="border-width: 0px;border-style: initial;border-color: initial">/bin/sh: python: 未找到命令</span></span></code>

显示python命令没有找到,很显著的就可以确定是环境变量的问题。这些方法定位问题十分有效。

良许花了一个半月的时间研制了一门Linux命令课程,欢迎订购学习!

课程特色:

详尽总结150个高频使用命令,学完可应对工作中95%命令需求;

答疑群提供无限次答疑服务,答疑群气氛挺好;

总时长超10小时,抗衡大课时长。

长按下方卡片订购

强烈推荐一位腾讯大鳄录制的Shell实战案例课程(已获授权):

大鳄在腾讯工作6年,在大厂工作十几年,经验丰富;

大鳄依据自己在大厂工作经验总结了100个案例,超级实用!

学完这100个案例,肯定对自己的Shell编程有很大的提高;

答疑群提供无限次答疑服务,答疑群气氛挺好。

长按下方卡片订购

linux任务计划不生效_linux计划任务整点执行_linux计划任务格式

以上是Linux下的crontab出现的问题和解决问题的解决办法的详细内容。更多信息请关注PHP中文网其他相关文章!

声明
本文转载于:ITcool。如有侵权,请联系admin@php.cn删除
互联网在Linux上运行吗?互联网在Linux上运行吗?Apr 14, 2025 am 12:03 AM

互联网运行不依赖单一操作系统,但Linux在其中扮演重要角色。Linux广泛应用于服务器和网络设备,因其稳定性、安全性和可扩展性受欢迎。

Linux操作是什么?Linux操作是什么?Apr 13, 2025 am 12:20 AM

Linux操作系统的核心是其命令行界面,通过命令行可以执行各种操作。1.文件和目录操作使用ls、cd、mkdir、rm等命令管理文件和目录。2.用户和权限管理通过useradd、passwd、chmod等命令确保系统安全和资源分配。3.进程管理使用ps、kill等命令监控和控制系统进程。4.网络操作包括ping、ifconfig、ssh等命令配置和管理网络连接。5.系统监控和维护通过top、df、du等命令了解系统运行状态和资源使用情况。

使用Linux别名提高自定义命令快捷方式的生产率使用Linux别名提高自定义命令快捷方式的生产率Apr 12, 2025 am 11:43 AM

介绍 Linux是一个强大的操作系统,由于其灵活性和效率,开发人员,系统管理员和电源用户都喜欢。但是,经常使用长而复杂的命令可能是乏味的

Linux实际上有什么好处?Linux实际上有什么好处?Apr 12, 2025 am 12:20 AM

Linux适用于服务器、开发环境和嵌入式系统。1.作为服务器操作系统,Linux稳定高效,常用于部署高并发应用。2.作为开发环境,Linux提供高效的命令行工具和包管理系统,提升开发效率。3.在嵌入式系统中,Linux轻量且可定制,适合资源有限的环境。

在Linux上掌握道德黑客的基本工具和框架在Linux上掌握道德黑客的基本工具和框架Apr 11, 2025 am 09:11 AM

简介:通过基于Linux的道德黑客攻击数字边界 在我们越来越相互联系的世界中,网络安全至关重要。 道德黑客入侵和渗透测试对于主动识别和减轻脆弱性至关重要

如何学习Linux基础知识?如何学习Linux基础知识?Apr 10, 2025 am 09:32 AM

Linux基础学习从零开始的方法包括:1.了解文件系统和命令行界面,2.掌握基本命令如ls、cd、mkdir,3.学习文件操作,如创建和编辑文件,4.探索高级用法如管道和grep命令,5.掌握调试技巧和性能优化,6.通过实践和探索不断提升技能。

Linux最有用的是什么?Linux最有用的是什么?Apr 09, 2025 am 12:02 AM

Linux在服务器、嵌入式系统和桌面环境中的应用广泛。1)在服务器领域,Linux因其稳定性和安全性成为托管网站、数据库和应用的理想选择。2)在嵌入式系统中,Linux因其高度定制性和高效性而受欢迎。3)在桌面环境中,Linux提供了多种桌面环境,满足不同用户需求。

Linux的缺点是什么?Linux的缺点是什么?Apr 08, 2025 am 12:01 AM

Linux的缺点包括用户体验、软件兼容性、硬件支持和学习曲线。1.用户体验不如Windows或macOS友好,依赖命令行界面。2.软件兼容性不如其他系统,缺乏许多商业软件的原生版本。3.硬件支持不如Windows全面,可能需要手动编译驱动程序。4.学习曲线较陡峭,掌握命令行操作需要时间和耐心。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
4 周前By尊渡假赌尊渡假赌尊渡假赌

热工具

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

功能强大的PHP集成开发环境

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

适用于 Eclipse 的 SAP NetWeaver 服务器适配器

将Eclipse与SAP NetWeaver应用服务器集成。

EditPlus 中文破解版

EditPlus 中文破解版

体积小,语法高亮,不支持代码提示功能