在centos7环境下,设置定时任务crontab来每天定时执行一个shell脚本,来定时运行一个写好的node程序。这个node程序在Windows server 2012环境下运行没有任何问题,但是放在Linux环境下运行,真的是惨不忍睹,bug一大堆。这里总结一下几个有代表性的问题。
1. /bin/bash^M: 坏的解释器: 没有那个文件或目录
在Windows环境下编写shell脚本 通过共享文件在linux环境下运行时会出现这个问题 如下图:
原因
这是为什么呢 因为在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: 权限不够
解决方案:运行“chmod u+x 文件名” 命令。
3.npm未找到命令
分析
一开始百度说是:Linux版本的node.js不会像windows版本一样,自动设置node的环境变量。所以就先设置全局node,步骤如下:
1. 首先在 root 目录下找到 .bash_profile 文件,编辑vim ~/.bash_profile
2. 找到 PATH=
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在执行命令或脚本时,HOME的基目录不是目标脚本所在位置,而可能是”HOME=/root”,所以需要设置此基目录HOME的正确值。
解决方法:
-
vi /etc/crontab
,找到HOME值(没有就新增); - 在HOME中加入执行脚本所在目录的路径,即 添加
HOME=/root/qianx/wd3_screenshot/bin