NodeJS ReadStream 一次不读取 bufferSize 字节

Tar*_*ill 5 buffer stream node.js

我有一个代码,其中 NodeJS 服务器读取文件并将其流式传输到响应,它看起来像:

var fStream = fs.createReadStream(filePath, {'bufferSize': 128 * 1024});
fStream.pipe(response);
Run Code Online (Sandbox Code Playgroud)

问题是,Node 每次读取文件正好是 40960 字节。但是,如果我的应用程序一次读取 131072 (128 * 1024) 个字节,它会更有效率(由于不适用于此问题的原因)。

有没有办法强制 Node 一次读取 128 * 1024 个字节?

Shw*_*har 9

接受的答案是错误的。您可以使用highWaterMark选项强制 Node 一次读取(128*1024)个字节。

var fStream = fs.createReadStream('/foo/bar', { highWaterMark: 128 * 1024 });

文档特别指出“可能缓冲的数据量取决于传递给流构造函数的 highWaterMark 选项。对于普通流,highWaterMark 选项指定总字节数。对于在对象模式下运行的流,highWaterMark 指定对象的总数。

另外,请参阅。默认缓冲区大小为 64 KB


Lau*_*rin 0

我是新来的,所以请耐心等待......

我在节点的来源中找到了这个:

var toRead = Math.min(pool.length - pool.used, ~~this.bufferSize);
Run Code Online (Sandbox Code Playgroud)

和:

var kPoolSize = 40 * 1024;
Run Code Online (Sandbox Code Playgroud)

因此,无论您提供什么,缓冲区大小似乎都限制为 40kb。您可以尝试更改代码中的值并重建节点。但这可能不是一个非常易于维护的解决方案......