- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我有点困惑,不知道我是否完全理解了 nodeJS 事件循环/非阻塞 I/O 概念。
假设在我的服务器中我有:
app.get('/someURL', AuthHandler.restrict, MainHandler.findAllStocksFromUser);
findAllStocksFromUser() 的定义如下:
findAllStocksFromUser(req,res) {
/* Do some terribly inefficient, heavy computation*/
res.send(/*return something*/);
}
现在假设有 5 个请求进入。据我了解,对于每个进入的请求,都会将一个回调(在本例中为 findAllStocksFromUser())添加到事件循环队列中,并且在每次滴答时调用回调。
问题:
“极其低效、繁重的计算”不会影响服务器在请求进入时有效接收请求并立即将其回调添加到队列中的能力,对吗?
但是“非常低效、繁重的计算”将阻塞其他回调,直到它完成并导致服务器以这种方式低效,对吧?
最佳答案
在 node.js 中,你的 Javascript 是单线程的。这意味着一次只能运行一段 Javascript。因此,一旦请求处理程序开始运行,它就会一直运行,直到它完全完成并返回到调用它的系统,或者直到它开始异步操作(数据库、文件、网络等),然后返回到调用它的系统。只有这样,其他请求才能开始处理。
因此,如果您的“繁重计算”确实是大量同步运行的 Javascript,那么在它运行时将不会处理其他请求。如果那个“繁重的计算”实际上有很多异步操作,那么当处理程序等待异步操作的响应时,其他请求将开始运行。
现在,针对您的具体问题:
So now let's say 5 requests come in. As I understand, with each request that comes in, a callback, in this case findAllStocksFromUser(), is added to the eventloop queue, and with every tick, the callbacks are called.
这不太正确。传入请求已排队,但它的排队级别远低于仅排队您的回调。它甚至在您的服务器的 Javascript 部分看到请求之前就已排队(在某处的 native 代码中)。
The "terribly inefficient, heavy computation" won't effect the server's ability to efficiently receive requests as they come in and immediately add their callbacks to the queue, correct?
传入的请求将由底层 TCP 基础设施或实现您的服务器(不在单线程 JS 中运行)的 node.js 中的 native 代码排队。因此,一段长时间运行的 Javascript 不会阻止传入请求排队(除非某些内部队列已满)。
But the "terribly inefficient, heavy computation" is going to block the other callbacks until it's done and cause the server to be inefficient in that way, right?
正确。如果这种低效、繁重的计算是同步代码,那么它会一直运行直到完成,并且在它运行时没有其他请求可以运行。
对于 node.js 中的繁重计算代码,通常的解决方案是重新设计它以使其运行得更快,或者尽可能使用异步操作,或者将其移出主进程并启动子进程或子进程集群来处理繁重的计算。然后,这允许您的主请求处理程序将这种繁重的计算视为异步操作,并允许其他事情在主 node.js 线程之外完成繁重的工作时运行。
虽然这有时需要更多的编码工作,但也可以将长时间运行的计算分成多个 block ,以便可以执行一个工作 block ,然后使用 setImmediate()
安排下一个 block 工作,允许在您的工作 block 之间处理其他排队的项目。由于这些天来设置一个工作池相当快,你可以将工作传递给它,我可能更喜欢这种方法,因为它还可以让你更好地利用多个 CPU,并且可以避免“分块”的复杂性以这种方式高效处理的工作和编写代码。
关于node.js - Node 事件循环困惑,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32468482/
我正在尝试将 WPF CodeBehid 事件(如 Event、Handler、EventSetter)转换为 MVVM 模式。我不允许使用 System.Windows.Controls,因为我使用
我可能误解了 Backbone 中的事件系统,但是当我尝试以下代码时什么也没有发生。当我向 Backbone.Events 扩展对象添加新属性时,它不应该触发某种更改、更新或重置事件吗?就像模型一样吗
我遇到了一个简单的问题,就是无法弄清楚为什么它不起作用。我有一个子组件“app-buttons”,其中我有一个输入字段,我想听,所以我可以根据输入值过滤列表。 如果我将输入放在我有列表的根组件中,一切
System.Timers.Timer 的 Elapsed 事件实际上与 System.Windows.Forms.Timer 的 Tick 事件相同吗? 在特定情况下使用其中一种比使用另一种有优势吗
嗨,这个 javascript 代码段是什么意思。(evt) 部分是如此令人困惑.. evt 不是 bool 值。这个怎么运作? function checkIt(evt) { evt
我正在使用jquery full calendar我试图在事件被删除时保存它。 $('calendar').fullCalendar ({
我有两个链接的鼠标事件: $('body > form').on("mousedown", function(e){ //Do stuff }).on("mouseup", function(
这是我的代码: $( '#Example' ).on( "keypress", function( keyEvent ) { if ( keyEvent.which != 44 ) {
我尝试了 dragOver 事件处理程序,但它没有正常工作。 我正在研究钢琴,我希望能够弹奏音符,即使那个键上没有发生鼠标按下。 是否有事件处理程序? 下面是我正在制作的钢琴的图片。 最佳答案 您应该
当悬停在相邻文本上时,我需要使隐藏按钮可见。这是通过 onMouseEnter 和 onMouseLeave 事件完成的。但是当点击另外的文本时,我需要使按钮完全可见并停止 onMouseLeave
我有ul标签内 div标签。我申请了mouseup事件 div标记和 click事件 ul标签。 问题 每当我点击 ul标签,然后都是 mouseup和 click事件被触发。 我想要的是当我点击 u
我是 Javascript 和 jQuery 的新手,所以我有一个非常愚蠢的疑问,请耐心等待 $(document).click(function () { alert("!"); v
我有一个邮政编码解析器,我正在使用 keyup 事件处理程序来跟踪输入长度何时达到 5,然后查询服务器以解析邮政编码。但是我想防止脚本被不必要地调用,所以我想知道是否有一种方法可以跟踪 keydown
使用事件 API,我有以下代码来发布带有事件照片的事件 $facebook = new Facebook(array( "appId" => "XXX", "se
首次加载 Microsoft Word 时,既不会触发 NewDocument 事件也不会触发 DocumentOpen 事件。当 Word 实例已打开并打开新文档或现有文档时,这些事件会正常触发。
我发现了很多相关问题(这里和其他地方),但还没有具体找到这个问题。 我正在尝试监听箭头键 (37-40) 的按键事件,但是当以特定顺序使用箭头键时,后续箭头不会生成“按键”事件。 例子: http:/
给定的 HTML: 和 JavaScript 的: var $test = $('#test'); $test.on('keydown', function(event) { if (eve
我是 Node.js 的新手,希望使用流运行程序。对于其他程序,我必须同时启动一个服务器(mongodb、redis 等),但我不知道我是否应该用这个运行一个服务器。请让我知道我哪里出了问题以及如何纠
我正在尝试使用 Swift 和 Cocoa 创建一个适用于 OS X 的应用程序。我希望应用程序能够响应关键事件,而不将焦点放在文本字段上/文本字段中。我在 Xcode 中创建了一个带有 Storyb
我有以下代码: (function(w,d,s,l,i){ w[l]=w[l]||[];w[l].push({
我是一名优秀的程序员,十分优秀!