将 bash 脚本作为 cron 作业运行并没有做任何事情

问题描述

我在 /home/pi/dev/app/script.sh一个 Bash 脚本

启动一个节点应用程序将“hello world”写入文件。 使用手动启动脚本工作正常。 节点应用程序:

const fs = require('fs');

let test = 'cron working';
fs.writeFile('temp.txt',test,(err) => {

    if (err) throw err;


    console.log('saved!');
});

Bash 脚本:

#!/bin/bash
node /home/pi/dev/app/index.js

但是:

运行crontab -e

添加行: 1 * * * * /bin/bash /home/pi/dev/app/script.sh

什么都不做。观察 tail -f /var/log/syslog 表明 cron 本身正在执行,但没有写入文件

我尝试添加 sudo nano /etc/crontab 1 * * * * root /bin/bash /home/pi/dev/app/script.sh 但这也不起作用。

我使用的是运行 debian 的 RPI4。

解决方法

如果启动 node 的 bash 脚本行只是“node index.js”,则可能是 crond 用户环境缺少 PATH 条目。如果 crond 以 root 身份运行,请检查 root 超级用户的默认环境,其 PATH 条目必须包含 node.js 路径。您可能还需要重新启动正在运行的 crond 或 kill -SIGHUP <crond pid> 以刷新其环境设置。

为了安全起见,请注意 node.js 路径仅对 root 超级用户可写。如果无法完成,那么在 bash 脚本中使用完整的 node.js 路径会更安全,而无需将 node.js 路径条目添加到 root 的 PATH 中。