expressjs不是异步处理我的请求

时间:2015-02-26 17:41:24

标签: javascript node.js asynchronous express nonblocking

var data = import('./blahblah/data')
app.get('/data', data.getData)
app.listen(3000)

// blahblah/data:
exports.getData = function(req, res) {
    setTimeout(function(){
        res.send('test')
    }, 10000)
};

//code I use to test
for(var i = 0;i<10;i++){
    $.ajax({
      url: 'http://127.0.0.1:3000/data',
      success: function(l){console.log(l);}
    });
}

如果我向此端点发送10个同时发出的请求,那么他们每隔10秒就会收到一个回复​​,最后一个请求在发送第一个请求后110秒。当其他请求运行异步代码时,Aren的nodejs和express应该让其他请求进行处理吗?

1 个答案:

答案 0 :(得分:6)

您的代码很好,可能是您测试它的方式有问题。

请确保您并行发送请求。

我使用loadtest utility

测试了您的代码
loadtest -n 10 -c 10 http://localhost:3000/data

并获得了预期的结果

Target URL:          http://localhost:3000/data
Max requests:        10
Concurrency level:   10
Agent:               none

Completed requests:  10
Total errors:        0
Total time:          10.050681130000001 s

这是我测试过的代码:

var app = require('express')();
app.get('/data', function(req, res) {
    setTimeout(function(){
        res.send('test')
    },10000)
});
app.listen(3000)

<强>更新

Web浏览器通常会限制每台主机的并行请求数。我刚刚在我的谷歌浏览器中对其进行了测试,它将并行请求的数量限制为6:

enter image description here

以下是延迟请求之一的详细时间:

enter image description here

看起来您的浏览器有更严格的限制。