Node.js 的无缓冲功能是什么
What is No-Buffering feature of Node.js
到处都提到 Node.js 没有缓冲功能。例如来自教程点:
No Buffering − Node.js applications never buffer any data. These applications simply output the data in chunks.
但这意味着什么? Node.js 有一个缓冲区 class 并且根据缓冲区 class 定义
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 所回避的内容,尽管说得不好 — 而且在大多数情况下是不正确的。
缓冲实际上是处理流数据的关键。
从某种意义上说,实际数据将驻留在缓冲区中,直到您的 Callback 将数据从流中拉出以供使用。
这就是为什么 Node.JS 有 Buffer classes 和 stream-buffers 等库来促进流数据访问的原因。
处理流和缓冲区的一个常见痛点是:“背压”
这是当你的数据流有一个 Producer 和一个 Consumer 时,但由于负载问题,你的消费者正在下降与生产者将数据泵入流的速度相比,在以足够快的速度消耗数据方面落后。
这会导致所谓的“背压”效应,如果生产者不受速率限制,可能会导致系统崩溃。
背压与讨论相关,因为它是由于缓冲区填充速度快于回调将数据推送回用户或其他流而引起的。
因此,缓冲 — 在某种程度上 — 对 Node.js 的操作至关重要,也是它处理连续数据流的方式。 这就是缓冲区 class 存在 以及流式缓冲区的原因 — 促进回调之间的数据移动。
到处都提到 Node.js 没有缓冲功能。例如来自教程点:
No Buffering − Node.js applications never buffer any data. These applications simply output the data in chunks.
但这意味着什么? Node.js 有一个缓冲区 class 并且根据缓冲区 class 定义
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 所回避的内容,尽管说得不好 — 而且在大多数情况下是不正确的。
缓冲实际上是处理流数据的关键。 从某种意义上说,实际数据将驻留在缓冲区中,直到您的 Callback 将数据从流中拉出以供使用。
这就是为什么 Node.JS 有 Buffer classes 和 stream-buffers 等库来促进流数据访问的原因。
处理流和缓冲区的一个常见痛点是:“背压”
这是当你的数据流有一个 Producer 和一个 Consumer 时,但由于负载问题,你的消费者正在下降与生产者将数据泵入流的速度相比,在以足够快的速度消耗数据方面落后。
这会导致所谓的“背压”效应,如果生产者不受速率限制,可能会导致系统崩溃。
背压与讨论相关,因为它是由于缓冲区填充速度快于回调将数据推送回用户或其他流而引起的。
因此,缓冲 — 在某种程度上 — 对 Node.js 的操作至关重要,也是它处理连续数据流的方式。 这就是缓冲区 class 存在 以及流式缓冲区的原因 — 促进回调之间的数据移动。