在NODEJS中连接ECONNREFUSED

时间:2014-05-26 07:02:13

标签: node.js

当我运行测试另一个文件example3.js的文件example4.js时出错。

这是我的代码:

**//file example 3**

var http = require('http');
var fs = require('fs');

// write out numbers
function writeNumbers(res) {

    var counter = 0;

    // increment global, write to client
    for (var i = 0; i<100; i++) {
        counter++;
        res.write(counter.toString() + '\n');
    }
}

// create http server
http.createServer(function (req, res) {

    var query = require('url').parse(req.url).query;
    var app = require('querystring').parse(query).file + ".txt";

    // content header
    res.writeHead(200, {'Content-Type': 'text/plain'});

    // write out numbers
    writeNumbers(res);

    // timer to open file and read contents
    setTimeout(function() {

        console.log('opening ' + app);
        // open and read in file contents
        fs.readFile(app, 'utf8', function(err, data) {
            if (err)
                res.write('Could not find or open file for reading\n');
            else {
                res.write(data);
            }
            // reponse is done
            res.end();
        });
    },2000);
}).listen(8382);

console.log('Server running at 8124/');


**//end of example 3**

**//file example 4**

var http = require('http');

//The url we want, plus the path and options we need
var options = {
    host: 'localhost',
    port: 8124,
    path: '/?file=secondary',
    method: 'GET'
};

var processPublicTimeline = function(response) {
    // finished? ok, write the data to a file
    console.log('finished request');
};

for (var i = 0; i < 2000; i++) {
    // make the request, and then end it, to close the connection
    http.request(options, processPublicTimeline).end();
}

错误是:

events.js:72
throw er; // Unhandled 'error' event
^
Error: connect ECONNREFUSED
at errnoException (net.js:904:11)
at Object.afterConnect [as oncomplete] (net.js:895:19)
Process finished with exit code 8

附件中包含相关文件(我在其中包含2个文件)。 有人知道什么问题吗?

2 个答案:

答案 0 :(得分:0)

我的猜测是你超出了操作系统对并发打开文件描述符的限制,因为你的客户端代码试图打开2000个并发连接。尝试使用ulimit实用程序来增加

答案 1 :(得分:0)

在代码中,您的服务器正在侦听端口号:8382,并且您的客户端正在尝试连接到端口号:8124,其中没有服务器侦听客户端。所以,你得到了ECONNREFUSED。