【发布时间】:2020-12-17 02:58:14
【问题描述】:
我有一个使用 discord.js 模块的 NodeJS 脚本。 当我通过终端执行它时,它可以完美运行。
const fs = require('fs');
const Discord = require('discord.js');
client = new Discord.Client(); client.on('ready', async() => {
console.log('I am ready!');
const dev = await client.users.fetch(2396720);
const json = JSON.stringify(dev);
fs.writeFile('/var/www/html/discord.json', json, function (err) {
if (err) throw err;
console.log('Saved!');
process.exit(0);
});
});
client.login('Mjky_Pn3Bk');
但是,当我使用 crontab 安排它时
* * * * * node /var/www/UserToJSON/index.js >> /tmp/results.log 2>&1
我收到此错误
/var/www/UserToJSON/node_modules/discord.js/src/client/Client.js:41
} catch {
^
SyntaxError: Unexpected token {
at createScript (vm.js:80:10)
at Object.runInThisContext (vm.js:139:10)
at Module._compile (module.js:617:28)
at Object.Module._extensions..js (module.js:664:10)
at Module.load (module.js:566:32)
at tryModuleLoad (module.js:506:12)
at Function.Module._load (module.js:498:3)
at Module.require (module.js:597:17)
at require (internal/module.js:11:18)
at Object.<anonymous> (/var/www/UserToJSON/node_modules/discord.js/src/index.js:8:11)
【问题讨论】:
-
在终端和通过 crontab 尝试
which node和node -v。发布输出。 -
来自 crontab 的 v8.17.0 和来自控制台的 v12.18.3。使用
which node时crontab不输出 -
好像crontab有不同版本的nodejs,正在寻找解决方案
-
您需要从您的发行版中卸载节点包。
-
which node通过 crontab 输出 /usr/bin/node /usr/local/bin/node 通过控制台