- android - RelativeLayout 背景可绘制重叠内容
- android - 如何链接 cpufeatures lib 以获取 native android 库?
- java - OnItemClickListener 不起作用,但 OnLongItemClickListener 在自定义 ListView 中起作用
- java - Android 文件转字符串
(我也将此作为问题发布在请求的 github 页面上 - link)
我有一个应用程序使用请求从内部 API 获取 API 数据。
我正在做一些测试,我们的应用程序在高负载下的扩展性似乎很差,而且 API 响应越来越慢。
我将其推断为我们正在使用的请求调用,看起来请求可能在队列中触发这些,而不是一次全部触发。这是一个显示此行为的测试脚本:
#!/usr/bin/env node
var request = require("request"),
logger = require("./logger.js"),
argv = require("optimist").argv;
var numRequests = argv.requests || argv.r,
requestsMade = 0,
wait = argv.wait || argv.w || 0,
url = argv.url || argv.u || "http://www.google.com",
requestApi = function(url,callback){
var requestTime = new Date().getTime();
request({
method: "GET",
uri: url
},function(err, response, body){
var totalTime = (new Date().getTime()) - requestTime;
callback(err, response, body, totalTime);
});
},
doRequest = function(){
requestsMade++;
if(requestsMade==numRequests) clearInterval(requestMaker);
var thisRequest = requestsMade;
logger.info("Firing Request #"+thisRequest);
requestApi(url,function(err, response, body, totalTime){
if(err){
logger.error("error contacting API ", err, "trying to request ",reqUrl," after ", totalTime, "ms");
} else {
logger.info("Api responded to request #"+thisRequest+" after ", totalTime, "ms");
}
});
};
logger.info("Starting Test with " + numRequests + " Requests.");
var requestMaker = setInterval(doRequest,wait);
(logger.js 只是一个用于打印时间戳和设置日志级别的日志记录工具)。
而且,谷歌的一个简单测试显示了增量减速:
$ node requestTester.js -r 20
[Wed 2011-11-2 11:2:24.575 GMT7] INF: Starting Test with 20 Requests.
[Wed 2011-11-2 11:2:24.580 GMT7] INF: Firing Request #1
[Wed 2011-11-2 11:2:24.654 GMT7] INF: Firing Request #2
[Wed 2011-11-2 11:2:24.661 GMT7] INF: Firing Request #3
[Wed 2011-11-2 11:2:24.664 GMT7] INF: Firing Request #4
[Wed 2011-11-2 11:2:24.667 GMT7] INF: Firing Request #5
[Wed 2011-11-2 11:2:24.672 GMT7] INF: Firing Request #6
[Wed 2011-11-2 11:2:24.673 GMT7] INF: Firing Request #7
[Wed 2011-11-2 11:2:24.674 GMT7] INF: Firing Request #8
[Wed 2011-11-2 11:2:24.675 GMT7] INF: Firing Request #9
[Wed 2011-11-2 11:2:24.675 GMT7] INF: Firing Request #10
[Wed 2011-11-2 11:2:24.676 GMT7] INF: Firing Request #11
[Wed 2011-11-2 11:2:24.677 GMT7] INF: Firing Request #12
[Wed 2011-11-2 11:2:24.678 GMT7] INF: Firing Request #13
[Wed 2011-11-2 11:2:24.679 GMT7] INF: Firing Request #14
[Wed 2011-11-2 11:2:24.680 GMT7] INF: Firing Request #15
[Wed 2011-11-2 11:2:24.681 GMT7] INF: Firing Request #16
[Wed 2011-11-2 11:2:24.682 GMT7] INF: Firing Request #17
[Wed 2011-11-2 11:2:24.683 GMT7] INF: Firing Request #18
[Wed 2011-11-2 11:2:24.684 GMT7] INF: Firing Request #19
[Wed 2011-11-2 11:2:24.685 GMT7] INF: Firing Request #20
[Wed 2011-11-2 11:2:25.257 GMT7] INF: Api responded to request #2 after 602 ms
[Wed 2011-11-2 11:2:25.621 GMT7] INF: Api responded to request #1 after 1041 ms
[Wed 2011-11-2 11:2:25.774 GMT7] INF: Api responded to request #3 after 1113 ms
[Wed 2011-11-2 11:2:25.779 GMT7] INF: Api responded to request #4 after 1115 ms
[Wed 2011-11-2 11:2:25.895 GMT7] INF: Api responded to request #5 after 1228 ms
[Wed 2011-11-2 11:2:26.378 GMT7] INF: Api responded to request #9 after 1703 ms
[Wed 2011-11-2 11:2:26.714 GMT7] INF: Api responded to request #7 after 2041 ms
[Wed 2011-11-2 11:2:26.870 GMT7] INF: Api responded to request #8 after 2196 ms
[Wed 2011-11-2 11:2:27.126 GMT7] INF: Api responded to request #10 after 2449 ms
[Wed 2011-11-2 11:2:27.267 GMT7] INF: Api responded to request #6 after 2595 ms
[Wed 2011-11-2 11:2:27.730 GMT7] INF: Api responded to request #14 after 3051 ms
[Wed 2011-11-2 11:2:28.68 GMT7] INF: Api responded to request #13 after 3389 ms
[Wed 2011-11-2 11:2:28.72 GMT7] INF: Api responded to request #11 after 3395 ms
[Wed 2011-11-2 11:2:28.75 GMT7] INF: Api responded to request #12 after 3398 ms
[Wed 2011-11-2 11:2:28.332 GMT7] INF: Api responded to request #16 after 3650 ms
[Wed 2011-11-2 11:2:28.471 GMT7] INF: Api responded to request #15 after 3791 ms
[Wed 2011-11-2 11:2:29.45 GMT7] INF: Api responded to request #18 after 4362 ms
[Wed 2011-11-2 11:2:29.161 GMT7] INF: Api responded to request #17 after 4479 ms
[Wed 2011-11-2 11:2:29.173 GMT7] INF: Api responded to request #19 after 4488 ms
[Wed 2011-11-2 11:2:29.424 GMT7] INF: Api responded to request #20 after 4738 ms
为什么会这样?是否有一个我错过的配置选项会立即触发所有请求?
我不想放弃请求,因为我非常喜欢它,但这是该项目的一个亮点。
最佳答案
如果您不想使用 v0.5.10(它已经接近稳定并且是即将到来的 Node v0.6.x 的候选者),您将不得不修补请求。在请求 main.js 中,替换行
var globalPool = {}
与
var globalPool = false
这应该会消除对并发连接的限制。
关于javascript - node.js request.js 不并行触发请求,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/7985218/
我用运行 Node node --debug app OR node --debug-brk app 它有反应 debugger listening on port 5858 Express serv
这个问题在这里已经有了答案: What is the difference between (int *i) and (int* i) in context of both C and C++? [
我有一个应用程序,它通过消息队列将数据库写入命令分派(dispatch)给工作人员(数量非常大),因此无法保证它们的接收顺序。 我有两个 Node ,例如“Account”和“Media”。在此假设的
有没有办法在调用 ts-node 时将选项传递给 Node ?我正在尝试在 Node 中使用一个实验性功能,如果它能与 ts-node 一起使用,那就太好了。 这就是我目前正在做的事情: ts-nod
我有一个容器化的Node应用程序,它在DigitalOcean服务器上运行。当我更新服务器上的应用程序时,该应用程序必须关闭一小段时间。为了能够更新应用程序并避免停机,我目前正在阅读零停机时间部署/蓝
我正在编写一个 Node.js 应用程序。我正在使用 request 和 Cheerio 加载一组 URL 并获取该网站的大量信息,现在假设我想要获取的只是标题: var urls = {"url_1
如果不弹出以下错误,我无法安装任何 Node.js 模块。错误代码引用package.json文件。如果知道为什么会发生这种情况,我们将不胜感激。 最佳答案 这些不是错误,它们只是警告。一切都应该如此
如果我运行(从我的项目目录中): supervisor javascripts/index.js 我得到:/usr/bin/env: Node :没有这样的文件或目录 如果我运行: node java
我已遵循使用 Node-Inspector 的所有步骤 但是当我打开应用程序时,我在控制台上看不到任何脚本或日志。 我的应用程序在端口 4000 上运行。我认为唯一可能发生冲突的是端口 8080 上的
我在android中使用rxjava2,有时会遇到这样的问题: Observable.fromArray( // maybe a list about photo url in SD
我目前正在使用 Node 光纤来编写同步服务器端代码。我主要通过 try-catch block 进行错误处理,但外部库或其他小部分异步代码中总是有可能发生错误。我正在考虑使用新的域功能来尝试将这些错
看起来node-debug是node-inspector周围的一个shell?分别什么时候应该使用? 最佳答案 如果您安装node-debug,您只能访问node-debug命令。 如果您安装node
我目前正在代理后面工作,该代理不允许我执行此命令的 HTTP GET 请求阶段: Node node-sass/scripts/build.js 请求阶段: gyp http GET https://
听说node js可以用在服务端。我以前用过jsp。 jsp页面内部的java代码对客户端是不可见的。如果 Node js 只是 javascript,那么它如何对客户端不可见? 最佳答案 首先,No
我正在为 Node native 插件从 node-waf 构建迁移到 node-gyp 构建系统。 node-gyp 说它支持多个目标版本,但我在使用 node-gyp 时找不到如何指定目标 Nod
给定一个 $node ,我正在尝试在以下两种输出该 $node 的方式之间做出决定。 要么 $output = theme('node', $node); 或 node_build_content($
如果package.json中的窗口A打开一个新窗口B,node-main如何访问它?这是我的代码: package.json { "main": "index.html",
我试图在我的 xml 中的特定节点 ( ) 之前插入一个注释节点。这是它的方法: function test(xmlResponse) { var parser = new DOMParse
我正在尝试做npm install wrtc使用 Node 版本 16.14.0 但这还没有完成。它在给npm error code 1所以我试图将 Node 版本更改为以前的 lts 14.19.0
当我在 Visual Studio 中运行 Node.js 应用程序时,我收到以下消息:DeprecationWarning: 'node --debug' 和 'node --debug-brk'
我是一名优秀的程序员,十分优秀!