这是我的代码:
我的数据库中有超过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();
}
答案 0 :(得分:5)
您的问题在于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秒就会触发一个新请求。