我尝试限制请求包maxsockets, 我使用fiddler来测试它使用并发的程度。
如我所见,它不适用我试图设定的10限制。
我不希望请求模块使用超过10个并发
我可能做错了什么?
process.env.NODE_TLS_REJECT_UNAUTHORIZED = "0";
var loglar='idler2.txt';
var url = require('url');
var util = require('util');
var http = require('http');
var https = require('https');
var request = require('request');
var fs = require('fs');
var linkler = [];
var starttime = Math.round(new Date().getTime() / 1000);
http.globalAgent.maxSockets = 10;
https.globalAgent.maxSockets = 10;
var timeoutsure = 30 * 1000;
var success=0,fail=0;
process.on('exit', onExit);
function onExit() {
console.log('\n%d secs,\n%d suc ,\n%d fail\n---------------------\n',
(Math.round(new Date().getTime() / 1000)) - starttime,success,fail);
}
function logla(data)
{
var fd = fs.openSync(loglar, 'a+');
fs.writeSync(fd, data);
fs.closeSync(fd);
}
for(i=0;i<1000;i++)
{
sorgutest();
}
var r = request.defaults({'proxy':'http://127.0.0.1:8888',pool: {maxSockets: 10}});
function sorgutest()
{
r.get({url:'https://freegeoip.net/json/',pool: {maxSockets: 10}}, function optionalCallback(err, httpResponse, body) {
if (err) {
fail++;
return console.error('failed: 49', err);
}
else {
try {bodyjson=JSON.parse(body);
logla(body);
success++;
}
catch(e){console.log("hamina 54");}
}
});
}
答案 0 :(得分:0)
如文件中所述:
请注意,如果您在循环中发送多个请求并创建多个新池对象,则maxSockets将无法按预期工作。要解决此问题,请将request.defaults与池选项一起使用,或者使用循环外部的maxSockets属性创建池对象。
尝试更改request.defaults的池选项或创建池对象并在所有请求调用上使用它。
编辑:
我注意到你已经使用了request.default,修复应该只是删除r.get调用中的pool选项。
自:
r.get({url:'https://freegeoip.net/json/',pool: {maxSockets: 10}}, function optionalCallback(err, httpResponse, body) {
至:r.get({url:'https://freegeoip.net/json/'}, function optionalCallback(err, httpResponse, body) {