gpt4 book ai didi

node.js - 什么是 Node.js 的无缓冲特性

转载 作者:搜寻专家 更新时间:2023-10-31 22:49:24 25 4
gpt4 key购买 nike

到处都提到 Node.js 没有缓冲功能。例如来自教程点:

No Buffering − Node.js applications never buffer any data. These applications simply output the data in chunks.

但这意味着什么? Node.js 有一个 Buffer 类,并且根据 Buffer 类定义

Pure JavaScript does not handle straight binary data very well, though JavaScript is Unicode friendly. When dealing with TCP streams and reading and writing to the filesystem, it is necessary to deal with purely binary streams of data.

这是正确的。

那么,Node.js中的“No Buffering”有什么特点呢?

Node.js 是如何坚持无缓冲的?谁能举例说明一下?

最佳答案

虽然 Node.js 允许您使用数据流(即分块数据),但这并不一定意味着“Node.js 从不缓冲数据”——这取决于开发人员来处理.

典型的流式传输是通过创建一个回调来完成的,该回调在一段时间内接收数据,对该数据执行某些操作,或者将其处理到另一个流。

这意味着数据的消费者可以更轻松地获取数据,而无需等待整个操作完成。

这就是 TutorialPoint 所回避的内容,尽管说得不好 — 而且在大多数情况下是不正确的。


缓冲实际上是处理流数据的关键。从某种意义上说,实际数据将驻留在缓冲区中,直到您的回调 将数据从流中拉出以供使用。

这就是为什么 Node.JS 有 Buffer 类和库,例如 stream-buffers,以促进流数据访问。


处理流和缓冲区的一个常见痛点是:“背压”


这是当您有一个包含生产者消费者的数据流时,但由于负载问题,您的消费者在快速消费数据方面落后了与生产者将数据泵入流的速度相比,速度足够快。

这会导致所谓的“背压”效应,如果生产者不受速率限制,可能会导致系统崩溃。

背压与讨论相关,因为它是由于缓冲区填充速度快于回调将数据推送回用户或其他流而引起的。

因此,缓冲 — 在某种程度上 — 对 Node.js 的操作至关重要,也是它处理连续数据流的方式。 这就是存在 Buffer 类以及 Streaming 缓冲区的原因 — 以促进回调之间的数据移动。

关于node.js - 什么是 Node.js 的无缓冲特性,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/42596571/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com