这是我的代码:
我的数据库中有超过 500,000 条记录,我想从另一台服务器循环并请求一些信息。我已经成功编写了除每个请求之间的延迟之外的所有函数。如果我使用 node 发送所有请求.js远程服务器会出现故障或无法回答每个请求。所以我需要创建一个循环队列,但我的代码不起作用,仍然非常快速地发送所有请求。
var http = require('http')
, mysql = require('mysql');
var querystring = require('querystring');
var fs = require('fs');
var url = require('url');
var client = mysql.createClient({
user: 'root',
password: ''
});
client.useDatabase('database');
client.query("SELECT * from datatable",
function(err, results, fields) {
if (err) throw err;
for (var index in results) {
username = results[index].username;
setInterval(function() {
requestinfo(username);
}, 5000 );
}
}
);
client.end();
}
您的问题在于 for 循环,因为您将所有请求设置为每 5 秒关闭一次。这意味着在 5 秒后,所有请求将相对同时触发。由于它是使用 setInterval 完成的,因此它将每 5 秒发生一次。
您可以通过两种方式解决它。
如果索引是数字,则首选是设置间隔以每 5 秒创建新请求,因此您可以执行以下操作,而不是 for 循环:
var index = 0;
setInterval(function(){
requestinfo(results[index].username);
index++;
}, 5000)
第二种选择是将所有请求设置为递增的超时,以便像这样修改当前脚本:
var timeout = 0;
for (var index in results) {
username = results[index].username;
setTimeout(function() {
requestinfo(username);
}, timeout );
timeout += 5000;
}
这将设置 0,5,10,15... 等秒的超时,因此每 5 秒触发一个新请求。