随机出现此错误当我的discord bot在线停留时间过长,大约3-4小时但有时错误会更早发生,有时甚至更晚。这真让我困扰。
events.js:188
throw err;
^
Error: Unhandled "error" event. ([object Object])
at Client.emit (events.js:186:19)
at WebSocketConnection.onError (D:\BasementMonster\node_modules\discord.js\src\client\websocket\WebSocketConnection.js:374:17)
at WebSocket.onError (D:\BasementMonster\node_modules\ws\lib\event-target.js:128:16)
at emitOne (events.js:116:13)
at WebSocket.emit (events.js:211:7)
at _receiver.cleanup (D:\BasementMonster\node_modules\ws\lib\websocket.js:211:14)
at Receiver.cleanup (D:\BasementMonster\node_modules\ws\lib\receiver.js:557:13)
at WebSocket.finalize (D:\BasementMonster\node_modules\ws\lib\websocket.js:206:20)
at emitOne (events.js:116:13)
at TLSSocket.emit (events.js:211:7)
at emitErrorNT (internal/streams/destroy.js:64:8)
at _combinedTickCallback (internal/process/next_tick.js:138:11)
at process._tickCallback (internal/process/next_tick.js:180:9)
答案 0 :(得分:8)
我用自己的代码为这个问题努力了一段时间。主要问题是跟踪完全没有帮助,并且 很少发生错误,从而使“在终端中运行并等待”是徒劳的任务。最终,我能够弄清楚Discord.js客户端本身正在引发错误-在我阅读的任何文档中都没有提及此错误,因此我没有针对它的处理程序-并且由于这种糟糕的情况发生在Discord.js包本身,在我的代码中没有行可以指向跟踪。
代码中某处需要存在的内容类似于
client.on('error', (err) => {
console.log(err.message)
});
当然,无论您的Client对象是什么,以及您希望错误处理的内容如何,都对此进行了调整。 据我所知,该特定跟踪来自丢失的互联网连接,这是我想要记录的内容,因此我不是使用console.log()而是调用了自己的自定义函数,该事件将事件写到日志文件中带有时间戳。
通过运行bot实例并终止我的Internet连接进行测试,结果表明,不仅日志记录功能有效,而且Discord.js在它回来后会自动恢复该会话。 (您的里程可能会有所不同。)
答案 1 :(得分:1)
您需要添加一个错误处理事件,如下所示:with