3

这是我的代码:

我的数据库中有超过 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();
}
4

1 回答 1

6

您的问题在于 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 秒触发一个新请求。

于 2012-09-20T09:17:17.533 回答