请教一个关于 readableStream 的问题

2019-07-03 10:44:07 +08:00
 divasatanica

因为想要手动控制流的暂停与继续消费 在看 Node.js 中文文档对 pause() 方法的描述

readable.pause()

使流动模式的流停止触发 'data' 事件,并切换出流动模式。 任何可用的数据都会保留在 内部缓存 中。

如果暂停了,流不会再触发 'data' 事件,但是 数据源 还会不会往流里面写数据,因为如果还会继续写数据的话,暂停消费数据会导致数据保存在缓存中,如果过一段时间之后仍然不继续消费数据,这个缓存会不会溢出?

谢谢各位。

4109 次点击
所在节点    Node.js
2 条回复
momocraft
2019-07-03 11:10:54 +08:00
ReadableStream 只是个 interface

本地文件的流可能可以随便 pause,来自另一台机器的流可能 pause 太久另一端就写超时了 (或者有一些字节被丢掉,或者 OOM kill)

使用流的人需要自己考虑好具体数据源能不能 pause,如果 pause 会有什么后果
divasatanica
2019-07-03 11:33:34 +08:00
@momocraft 数据源是 mongodb,现在场景是流式导出 csv,我的想法是,如果 pause 太久 mongodb 写超时的话,加入一个 pause 超时机制,到达一定时间还没有 resume,就认为是超时,然后再 resume 这个流,前提是能接受部分数据的丢失,这样想科学吗?

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/579538

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX