mongoose的报错:timed out 和 socket closed 有什么区别?分别在什么情况下出现?

发布于 2022-09-06 23:03:13 字数 872 浏览 14 评论 0

最近生产环境中发现一个读取数据的接口返回时间过长。
项目使用的是 nodejs + mongodb
开发使用的依赖:

  "dependencies": {
    "express": "2.5.10",
    "iconv-lite": "^0.4.13",
    "ioredis": "^1.15.1",
    "log4js": "^0.6.35",
    "mongoose": "^4.4.13",
    "node-schedule": "~1.0.0",
    "node-xlsx": "^0.4.0",
    "superagent": "3.8.2"
  }

查看日志的时候,发现报错信息是:
生产环境报错信息

我们猜想是由于网络原因,导致服务于数据库链接问题,所以我们用类似的环境想复现此为问题。

复现的过程是用 wrk 工具连续访问用一个接口一段时间,在此时间内设置服务器防火墙,模拟断网情况。
结果得到的报错信息如下:
测试环境报错信息

问题如题:

  1. mongoose的报错:timed out 和 socket closed 有什么区别?
  2. 分别在什么情况下出现?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

白首有我共你 2022-09-13 23:03:13

我的理解是timed out属于被动关闭,服务器不响应也不理你,socket closed属于主动关闭,服务器直接就拒绝了。mongoose监听timedoutclose(had_error)只是为了区分错误类型,最终都执行了socket.end()

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文