crontab定时任务不能自动执行的bug总结

时间:2021-01-01 07:49:47

在centos7环境下,设置定时任务crontab来每天定时执行一个shell脚本,来定时运行一个写好的node程序。这个node程序在Windows server 2012环境下运行没有任何问题,但是放在Linux环境下运行,真的是惨不忍睹,bug一大堆。这里总结一下几个有代表性的问题。

1. /bin/bash^M: 坏的解释器: 没有那个文件或目录

在Windows环境下编写shell脚本 通过共享文件在linux环境下运行时会出现这个问题 如下图:

crontab定时任务不能自动执行的bug总结

原因

这是为什么呢 因为在Windows环境下我们回车时 是 \n\r
而在linux环境下 回车 是 \n
所以会多了一个 \r
而这个 \r 在这里的体现就是 ^M
不信 你可以 输入命令 cat filename -A 就会在每一句的末尾打印出 ^M 这个符号 就是换行

那怎么解决这个问题呢

解决方法

在linux下输入命令 sed -i ‘s/\r$//’ filename
该命令的作用是:将文件中的所有\r替换成空格
接下来你在执行shell脚本就OK了 (./filename)

2.startup.sh: 权限不够

crontab定时任务不能自动执行的bug总结

解决方案:运行“chmod u+x 文件名” 命令。

3.npm未找到命令

crontab定时任务不能自动执行的bug总结

分析

一开始百度说是:Linux版本的node.js不会像windows版本一样,自动设置node的环境变量。所以就先设置全局node,步骤如下:
1. 首先在 root 目录下找到 .bash_profile 文件,编辑vim ~/.bash_profile
2. 找到 PATH= P A T H : HOME/bin,在后面添加路径为:
PATH=$PATH:$HOME/bin:/usr/local/src/node/bin
3. 保存修改,然后重载一下: source ~/.bash_profile
现在可以在任何目录下执行node和npm命令了!详见:https://segmentfault.com/a/1190000008479977

等到crontab再次自动执行时,还是报这个错。。
很奇怪,此时明明对node.js已经设置了全局的环境变量,可以在全局使用npm了,为啥还会提示“npm未找到命令”呢?

原因

crond的任务计划, 有并不会调用用户设置的环境变量,它有自己的环境变量,当你用到一些命令时,比如mysqldump等需要环境变量的命令,手工执行脚本时是正常的,但用crond执行的时候就会不行,这时你要么写完整的绝对路径,要么将环境变量添加到 /etc/crontab 中。

解决方法:

  • vi /etc/crontab,找到PATH值;
  • 在PATH中加入node.js的配置路径,即 将PATH=/sbin:/bin:/usr/sbin:/usr/bin改成PATH=/sbin:/bin:/usr/sbin:/usr/bin:/usr/local/src/node/bin

当crontab再次执行

4.no such file or directory

npm ERR! enoent ENOENT: no such file or directory, open ‘/package.json’
crontab定时任务不能自动执行的bug总结

原因:

crontab在执行命令或脚本时,HOME的基目录不是目标脚本所在位置,而可能是”HOME=/root”,所以需要设置此基目录HOME的正确值。

解决方法:

  • vi /etc/crontab,找到HOME值(没有就新增);
  • 在HOME中加入执行脚本所在目录的路径,即 添加HOME=/root/qianx/wd3_screenshot/bin