<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在线解析工具。
工具地址:
给出这个工具的截图如下:
好用不好用,你试试就晓得。
五、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>
这个似乎是在执行计划任务命令之前,先加载了用户环境变量信息,由此可保证所有环境变量都可正常加载。
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输出内容如下:
<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下的crontab出現的問題與解決問題的解決方法的詳細內容。更多資訊請關注PHP中文網其他相關文章!