Javascript 节点Js中每个请求之间的延迟为5秒
这是我的密码: 我的数据库中有超过500000条记录,我想循环并从另一台服务器请求一些信息。我已经成功地编写了所有函数,除了每个请求之间的延迟。如果我使用node.js发送所有请求,远程服务器将出现故障或无法响应每个请求。所以我需要创建一个循环队列,但我的代码无法正常工作,仍然可以非常快地发送所有请求Javascript 节点Js中每个请求之间的延迟为5秒,javascript,node.js,setinterval,Javascript,Node.js,Setinterval,这是我的密码: 我的数据库中有超过500000条记录,我想循环并从另一台服务器请求一些信息。我已经成功地编写了所有函数,除了每个请求之间的延迟。如果我使用node.js发送所有请求,远程服务器将出现故障或无法响应每个请求。所以我需要创建一个循环队列,但我的代码无法正常工作,仍然可以非常快地发送所有请求 var http = require('http') , mysql = require('mysql'); var querystring = require('querystring'); v
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的超时。。。etc秒,因此每5秒就会触发一个新请求。我希望逐个发送请求您的问题代码缺少查询本身的信息。如果它与节点请求通常是异步的,那么您应该放弃定义的延迟,并在requestInfo回调中启动一个新的请求。这将在旧请求得到答复后立即创建新请求。