了解Node.JS async.parallel

时间:2013-11-25 06:28:44

标签: javascript node.js parallel-processing

我需要从两个Web服务器请求数据。任务是独立的;因此,我正在使用aync.parallel。现在我只在我的网页正文中写'abc','xyz'和'Done'。

由于任务是同时执行的,我可以遇到奇怪的输出吗?如,

xab
cyz

代码。

var async = require('async');

function onRequest(req, res) {
    res.writeHead(200, {
        "Content-Type" : "text/plain"
    });

    async.parallel([ function(callback) {
        res.write('a');
        res.write('b');
        res.write('c\n');
        callback();
    }, function(callback) {
        res.write('x');
        res.write('y');
        res.write('z\n');
        callback();
    } ], function done(err, results) {
        if (err) {
            throw err;
        }
        res.end("\nDone!");
    });

}

var server = require('http').createServer(onRequest);
server.listen(9000);

1 个答案:

答案 0 :(得分:47)

如果您想完全确定打印结果的顺序,则应将数据(abc\nxyz\n)传递到callbacks(第一个参数是错误)并在最终async.parallel回调的results参数中处理/写入它们。

async.parallel({
    one: function(callback) {
        callback(null, 'abc\n');
    },
    two: function(callback) {
        callback(null, 'xyz\n');
    }
}, function(err, results) {
    // results now equals to: results.one: 'abc\n', results.two: 'xyz\n'
});