- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我有一个应用程序,我按顺序从服务器下载 mp3 文件,将它们临时存储在我的服务器中,然后将它们直接流式传输到客户端,如下所示:
function downloadNextTrack(){
var request = http.get('http://mp3server.com', function(response){
response.on('data', function(data) {
fs.appendFile('sometrack.mp3', data, function (err) {});
});
response.on('end', function(){
streamTrack('sometrack.mp3');
}
});
};
var clients = []; // client response objects are pushed to this array when they request the stream through a route like /stream.mp3
var stream;
function streamTrack(track){
stream = fs.createReadStream(track);
stream.on('data', function(data){
clients.forEach(function(client) {
client.write(data);
});
});
stream.on('end', function(){
downloadNextTrack(); // redoes the same thing with another track
}
};
显然这段代码正在创建大量操作系统未释放的缓冲区,当我运行“free -M”命令时,这就是我得到的结果(在运行应用程序大约 4 小时后):
total used free shared buffers cached
Mem: 750 675 75 0 12 180
-/+ buffers/cache: 481 269
Swap: 255 112 143
“缓冲区”下的数字不断增加(以及缓存的内存)并且操作系统显然不会回收那 180mb,直到最终我的应用程序内存不足并在我尝试生成一个小进程来验证时崩溃轨道的比特率、采样率、id3 信息等。
我已经使用许多不同的工具(例如 memwatch 和 nodetime)进行诊断,以确定它是否是内部内存泄漏,而事实并非如此,V8 内存堆以及 Node RSS 变化 +/- 10mb但大部分情况下保持不变,而操作系统可用内存越来越低(当 Node 进程启动时,我有大约 350MB 的可用内存)。
我在某处读到,Node 分配的 Buffer 实例可以直接访问原始内存,因此 V8 无法控制它们(这证实了我没有从 V8 堆中获取内存泄漏这一事实),这件事是,我需要一种方法来摆脱这些旧缓冲区。这可能吗?或者我是否必须每 5 小时左右重新启动我的应用程序(或者更糟,购买更多 RAM!)?
附言。我在 Ubuntu 10.04 上运行 Node v0.8.16。
最佳答案
我同意蒂亚戈的观点,我认为这是由于代码的递归性质造成的。我不认为流会吞噬您的堆,因为正如您所说,每次迭代都会使用新的 ReadStream 重新分配流变量。但是,第 2 行中的 http.get 请求和响应(以及它们使用的任何缓冲区)在调用下一次迭代之前永远不会被释放;它们在 downloadNextTrack 函数范围内。您最终得到一个递归堆栈跟踪,每个文件都有一组请求和响应对象(以及一些底层缓冲区)。
一般来说,如果这段代码需要运行很多很多次,为什么不选择退出递归并全部迭代呢?永无休止的递归总是会吞噬越来越多的内存,直到程序崩溃,即使您没有内存泄漏也是如此。
关于javascript - Node : How to free buffers that get allocated outside of the V8 memory heap,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14065611/
N3485 20.6.9.1 [allocator.members]/1 说: Calls to these functions that allocate or deallocate a parti
我想编写一个调用 createHook() 的自定义分配器在对象构造和对称之后 destroyHook()就在对象销毁之前。我以这种方式使用我的分配器: class Object {}; class
我正在用 C++ 重新创建一个链表,并且在重载 += 运算符时得到了一个错误的指针。我想我只是以错误的方式使用了分配器,但我可能是错的。 这里是上下文: void MyLinkedList::oper
Allocator concept和 std::allocator_traits没有说明 allocate 是否会抛出。 所以当我使用分配器编写容器时,如何知道是检查返回类型还是使用 catch? 最
C++20 删除了 construct()和 destruct()成员(member)来自 std::allocator .我应该如何构造通过 std::allocator::allocate() 分
这个问题听起来可能相当初级,但这是我与另一位合作开发人员的辩论。 我注意在可能的地方分配堆栈,而不是堆分配它们。他在和我说话并看着我的肩膀并评论说没有必要,因为他们在表现方面是一样的。 我一直认为堆栈
这个问题听起来可能相当初级,但这是我与另一位合作开发者的争论。 我一直在尽可能地堆栈分配东西,而不是堆分配它们。他一边跟我说话,一边看着我,并评论说没有必要,因为它们在性能方面是相同的。 我一直认为堆
在 Java 程序中,当需要分配数千个相似大小的对象时,最好(在我看来)有一个“池”(这是一个单一的分配),其中包含可以从中提取的保留项目需要的时候。这个单一的大分配不会像数千个较小的分配那样使堆碎片
我正在尝试使用 TBB 来提升使用 OpenCV 的计算机视觉项目的性能。这是代码中给出访问冲突的部分。 #include #include "opencv2/objdetect/objdetect
我对一个问题有疑问,特别是关于 this 的问题回答。 有一部分留给读者作为练习(这本身不是问题),特别是 Jonathan Wakely(答案的作者)说: This code asserts tha
Allocator concept和 std::allocator_traits不要说当分配失败时 allocate 会做什么——它会返回 nullptr 还是抛出异常? 当我使用标准分配器 API
我有充分的理由不应该做这样的事情吗?示例: 我有一个类(class)MyClass。在那里我有这个实现: - (id)copyWithZone:(NSZone*)zone { MyClass
相关但不重复:请参阅此答案的底部,在单击此问题下方的“关闭”按钮之前,我解决了您可能想要声明的重复项。 自动生成 ROS (Robot Operating System) message C++ 头文
据我所知std::allocator::construct在旧版本的 C++ 上仅需要两个参数;第一个是指向原始的、未构造的内存的指针,我们要在其中构造 T 类型的对象。第二个是用于初始化该对象的元素
40个不同的分配函数给40个不同的调用点 void f00(size_t sz) { void* ptr = malloc(sz); free(ptr); } void f01(size_t sz)
我在使用 RenderScript 时一直遇到内存管理问题,所以我认为由于 Allocation.createFromBitmap()/createTyped() 消耗内存,Allocation.de
我正在尝试使用 valgrind 跟踪段错误。我从 valgrind 收到以下消息: ==3683== Conditional jump or move depends on uninitialise
实际上,我正在尝试创建一个包含 n 个多媒体文件(包括图像和视频)的应用程序。我的应用程序大小约为 34MB,我的 Assets 大小约为 60mb。当我在普通设备上加载应用程序时,我们没有遇到任何问
STL 容器有一个模板参数可以选择自定义分配器。花了一段时间,但我想我明白它是如何工作的。不知何故,它并不是很好,因为给定的分配器类型没有直接使用,而是反弹到另一种类型的分配器。我终于可以使用它了。
new int[0]在 C++ 中是允许的,但 std::allocator().allocate(0)定义好? 更一般地说,所有分配器都必须接受 0作为参数分配? 编辑: 阅读答案后,我测试了 Vi
我是一名优秀的程序员,十分优秀!