Node.js未处理的“错误”事件

发布于 2021-01-31 23:09:31

当我的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
被浏览
751
1 个回答
  • 面试哥
    面试哥 2021-01-31
    为面试而生,有面试问题,就找面试哥。

    我在自己的代码中为这个问题努力了一段时间。主要问题是跟踪是完全无用的, 并且
    错误很少发生,以至于使“在终端中运行并等待”是徒劳的任务。最终,我能够弄清楚Discord.js客户端本身正在引发错误-
    在我阅读的任何文档中都没有提到此错误,因此我没有针对它的处理程序-并且由于这种糟糕的情况发生在Discord.js包本身,在我的代码中没有行可以指向跟踪。

    需要在某处代码中存在的东西类似于

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

    当然,无论您的Client对象是什么,以及您希望错误处理的内容如何,​​都可以对其进行调整。据我所知,此特定跟踪来自丢失的互联网连接,这是我想要记录的内容,因此我代替了console.log()调用了自己的自定义函数,该事件将事件写到日志文件中带有时间戳。

    通过运行bot实例并终止我的Internet连接进行测试,结果表明,不仅日志记录功能有效,而且Discord.js在它回来后会自动恢复该会话。(你的旅费可能会改变。)



知识点
面圈网VIP题库

面圈网VIP题库全新上线,海量真题题库资源。 90大类考试,超10万份考试真题开放下载啦

去下载看看