- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我一直在我们的网络应用程序中遇到一个非常奇怪且看似随机的问题,我似乎无法成功调试。它在 10 分钟到 6 小时的任何时间都运行良好,然后突然之间无法向服务器发出远程请求或从服务器发出远程请求,它们只是挂起(这包括常规的 http 和 web 套接字请求)。奇怪的是,定期访问该站点仍然有效,直到达到操作系统文件描述符限制,然后 http 因所有停止的连接而完全崩溃。
虽然在问题开始时会抛出以下错误,但没有错误(我认为这是发生的任何事情的副作用而不是原因)。
TypeError: Cannot read property '0' of null
at null.<anonymous> (/app/node_modules/mongojs/node_modules/mongodb/lib/mongodb/collection.js:504:22)
at args.(anonymous function) (/app/node_modules/strong-agent/lib/proxy.js:85:18)
at g (events.js:175:14)
at EventEmitter.emit (events.js:98:17)
at Base.__executeAllServerSpecificErrorCallbacks (/app/node_modules/mongojs/node_modules/mongodb/lib/mongodb/connection/base.js:315:29)
at /app/node_modules/mongojs/node_modules/mongodb/lib/mongodb/connection/repl_set/ha.js:273:22
at /app/node_modules/mongojs/node_modules/mongodb/lib/mongodb/connection/repl_set/ha.js:370:11
at /app/node_modules/mongojs/node_modules/mongodb/lib/mongodb/connection/repl_set/ha.js:352:28
at _callback (/app/node_modules/mongojs/node_modules/mongodb/lib/mongodb/db.js:670:5)
at /app/node_modules/mongojs/node_modules/mongodb/lib/mongodb/auth/mongodb_cr.js:47:13
我已经尝试提高文件描述符限制和全局代理 maxSockets 而不影响此行为。发生这种情况时不会有流量涌入,而且在高峰期和非高峰期同样频繁发生。 CPU 使用率始终保持在 5% 以下,并且在崩溃之前或期间没有任何可察觉的变化。服务器的空闲内存也永远不会低于 1GB。
堆栈:SmartOS 云服务器 (Joyent)、Express、Socket.io、MongoDB 和 Redis。
我已经调试了好几天了,完全不知道该去哪里找。希望 SO 上的某个人遇到过类似的事情,或者对可以尝试或测试的内容有不同的想法。
最佳答案
经过无数个小时的调试和更多的调试,我终于找到了罪魁祸首。在几个不同的 mongojs 回调中抛出了一个错误,这些回调似乎已经冒泡并阻止了连接关闭。随着时间的推移,这达到了一个临界点,连接开始挂起,直到达到文件描述符限制。
原来错误出在Now.js Node 模块(已废弃)。如果有人在使用 Now.js 时遇到此问题,我将其 fork 并修补了该错误。你可以在这里找到提交:https://github.com/goldfire/now/commit/b5bd54f8950602f752a710c606be6754b759cab2 .
我发现此错误的方法是将错误监听器附加到 DB 对象:
var db = require('mongojs').connect('...', ['collection']);
db.client.on('error', function(err){
console.log(err.stack);
});
关于javascript - Node.js 请求随机开始挂起,直到服务器重启才会清除,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/18770284/
我有一个 UWP 应用程序(在 Windows/Microsoft Store 中发布),我正在进行新的更新,我在我的应用程序中使用了 Template10,它具有深色和浅色主题,并且在 Window
我是 spring batch 的新手,有一些关于暂停/恢复的问题。看了spring batch的文档,好像没有内置的pause或者resume功能。但是,我从主站点找到了这个用例: http://d
我正在编写一个网络服务并有以下观察结果:即使我只是将一个文本文件添加到存储 web 服务引用的所有 dll 的目录 (bin),appdomain 也会刷新。 这会导致存储在字典(在其中一个 dll
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 6 年前。 Improve this qu
Hadoop 1.0.3 工作 36 小时后说: INFO mapred.JobClient: map 42% reduce 0% mapred.JobClient: Job Failed
我使用 AVAssetWriter 将视频录制到文件中。所以我为此创建了类。 link to gist 然后在项目的某处我推送记录并开始录制视频。 func start() { assetWriter
我想要一个在后台运行的 python 脚本(无限循环)。 def main(): # inizialize and start threads [...] try:
我在重新启动 Activity 时感到困惑。我有两个功能可以很好地完成同一任务。请指导我哪个最好,为什么? public void restart() { Intent
重启sidekiq的正确方法是什么。它似乎在我启动它时缓存了我的 worker 代码,所以每次我对我的 worker 进行更改时我都需要重新启动它。我正在使用 Ctrl/C 执行此操作,但该过程需要很
我在我的 Android 模拟器上安装了新字体。说明说我必须重新启动设备。我尝试使用“关机”按钮,但它只显示“正在关机”并且什么也不做。即使我去 adb shell 并运行“重启”它也会挂起。 任何想
启动操作 ? 1
关闭 service nginx stop systemctl stop nginx 启动 service nginx start systemctl start n
正在学习Linux中。。。一边学一边记录着。。所有观点只是个人观点 Linux有个文件 /etc/inittab 复制代码 代码如下:
如果我运行 systemctl restart kubelet它会影响其他正在运行的节点吗?它会停止集群吗?你能预见任何影响吗? 任何帮助,将不胜感激! 最佳答案 在回答之前,小声明:重启不是由于对
嗯,问题是我有一个在 MATE 上完美运行的 Abyssus Razer,但是 在 Debian、Elementary、OpenSUSE 和其他平台上,默认 设置 super 慢。 我用 解决了这个问
我在 Ubuntu 16.04 上安装了 NGINX 并编辑了我的配置。 当我想用 sudo service nginx restart 重新启动时我得到错误: Job for nginx.servi
我已经在我的 Ubuntu 上安装了 Gearman Job Server(又名 Gearmand)1.0.6: Distributor ID: Ubuntu Description: Ubun
我有一个 WiX Burn使用 ManagedBootstrapperApplicationHost 的自定义安装程序。安装必备 Microsoft Windows Installer 之一后4.5
我已经使用 brew install mosquitto 在我的 mac 上安装了蚊子代理. 通常我不会给出任何命令来启动 mosquitto 服务器。当我打开我的 mac 时它会自动启动。 我已经使
我有一个带有 2 个容器的 pod test-1495806908-xn5jn。我想重新启动其中一个名为 container-test 的项目。是否可以重新启动 Pod 中的单个容器以及如何重新启动?
我是一名优秀的程序员,十分优秀!