Node.js 未处理的 "error"事件

标签 node.js

当我的 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)

最佳答案

我在自己的代码中为这个问题苦苦挣扎了一段时间。主要问题是跟踪完全没有帮助,并且错误很少发生,以至于“在终端中运行它并等待”成为徒劳的任务。最终,我发现 Discord.js 客户端本身正在抛出错误——我阅读的任何文档中都没有提到这一点,所以我没有针对它的处理程序——而且由于这个 oopsie 发生在Discord.js 包本身,我的代码中没有任何行可以在跟踪中指向它。

代码中某处需要存在的东西是

client.on('error', (err) => {
   console.log(err.message)
});

当然,无论您的 Client 对象是什么,以及您希望错误处理是什么,这都会进行调整。 据我所知,这个特定的跟踪来自丢失 Internet 连接,这是我想要记录的东西,所以我调用了我自己的自定义函数,而不是 console.log() 将事件写入日志文件带有时间戳。

通过运行 bot 的一个实例并终止我的 Internet 连接来对此进行测试表明,不仅日志记录功能有效,而且 Discord.js 在 bot 恢复后自动恢复 session 。 (您的里程可能会有所不同。)

关于Node.js 未处理的 "error"事件,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/50531293/

相关文章:

javascript - Nodejs 请求从服务器返回空正文作为 POST 请求

node.js - 如何从 nodejs Google Tasks API 中的任务列表中获取具有截止日期的任务?

node.js - MongoError : user is not allowed to do action [find] on [test.用户]

javascript - 如何在react.JS中将子窗口url获取到父窗口中?

javascript - 如何重试功能?

node.js - 我如何使用 Forever With Express 来保持 NodeJS 服务器的运行?

javascript - Express 应用程序主体解析器不适用于某些 api.s

angularjs - 前端 API 调用和后端 API 调用任何外部后端服务器之间的区别 代码

javascript - 当从同一个文件请求时,导出同一目录下的两个模块不起作用

javascript - 是否有 TCP 套接字库/协议(protocol)可以进行消息分帧并受 JS 和 C# 支持?