gpt4 book ai didi

javascript - Node.js 如何处理传入的请求?

转载 作者:行者123 更新时间:2023-12-05 04:58:31 25 4
gpt4 key购买 nike

为了深入了解有关 Node.js 的更复杂的概念,我正在做一些研究以确保我了解有关该语言的原则以及它构建的基本构建 block 。

就我而言,Node.js 依赖于 react 器模式 来处理每个传入请求。该算法基于事件多路分解器 算法。第二个负责处理请求操作及其资源,一旦操作完成,它将“结果”添加到事件队列。在此过程之后, Event Loop 现在负责为每个事件执行处理程序。

作为单线程进程,如果事件循环并行管理所有事件队列任务,我很难理解事件多路分配器如何处理所有传入操作...

我在 Node.js documentation 中找到了这个:

Since most modern kernels are multi-threaded, they can handle multipleoperations executing in the background. When one of these operationscompletes, the kernel tells Node.js so that the appropriate callbackmay be added to the poll queue to eventually be executed. We'llexplain this in further detail later in this topic.

这是否意味着 Event Demultiplexer 任务不由 Node 处理,Node 只是获取结果以便将其添加到 Event Queue?这是否意味着 Node 不是单线程的?

我在网上找到了一些有用的图形,可以清楚地解释每个请求遵循的路径,但是很难找到一些解释线程处理每个请求的实际时间的图形。

最佳答案

在 node.js 中,它在单个线程中运行您的 Javascript(假设我们不是在谈论工作线程或集群)。但是,node.js 内置库中的许多异步操作(例如文件 I/O 或一些加密操作)使用它们自己的线程来完成它们的任务。因此,当您调用诸如 fs.open() 之类的异步操作来打开文件时,它会转换为 native 代码,从内部线程池中获取一个线程,然后该线程开始打开文件。 fs.open() 函数然后返回到您的 Javascript(线程在后台继续运行)。稍后当它完成它的任务时,内部线程将一个事件插入到 nodejs 事件队列中,当 nodejs 有周期检查事件队列时,它会找到该事件并运行与其关联的 Javascript 回调以将异步结果提供回你的 Javascript。

因此,即使可能涉及线程,您的 Javascript 在事件循环中仍然是单线程的。

因此,nodejs 确实使用了原生代码线程来进行一些内部原生代码操作。网络和计时器等其他东西是在没有线程的情况下实现的。

Then if I send a request to fetch data from a database in Node, how does the Event Demultiplexer process It? Does the main thread stop the event loop to handle that operation and then resumes after the event handler is queued?

诸如“事件多路分解器”之类的术语是您应用于 node.js 的东西。它们根本不是 node.js 使用的东西,所以我不完全确定你在问什么。

Node.js 一次运行一个事件。它没有中断驱动的能力。因此,它会运行一个事件,直到该事件将控制权返回给事件循环(通过从启动一切的回调发出 return )。现在,原始事件可能还没有完成——它可能正在做一些异步的事情,这将触发另一个事件来宣布完成,但它现在已经完成运行 Javascript 并将控制权返回给事件循环。

当传入的 Fetch 请求(只是传入的 http 请求)到达服务器时,它首先由操作系统排队。然后,当事件循环有机会看到它时,它被添加到 node.js 事件队列中,并在它之前的其他事件完成处理后以 FIFO 顺序提供。现在,nodejs 事件循环不像单个事件队列那么简单。它实际上有几个不同的队列用于不同类型的工作,并且有先运行的优先级,但在最简单的级别上,您可以开始将其视为单个 FIFO 队列。而且,一切都不会中断。

从事件队列中拉出一个事件,运行与之关联的 Javascript 回调。当该回调返回到事件循环时,获取下一个事件并执行相同的操作。

事件可以通过 native 代码线程添加到事件队列(比如可能通过文件 I/O 或一些加密操作完成)或通过事件循环中内置的一些轮询机制作为它检查的事件循环周期的一部分对于某些准备运行的东西(如网络和计时器)。

关于javascript - Node.js 如何处理传入的请求?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63923294/

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