简单的nodejs http代理失败,“打开的文件太多”

时间:2011-03-16 05:31:50

标签: node.js

好吧,忽略它。我已经打开了一个问题https://github.com/joyent/node/issues/793

尝试运行http://www.catonmat.net/http-proxy-in-nodejs

var http = require('http');

http.createServer(function(request, response) {
  var proxy = http.createClient(80, request.headers['host'])
  var proxy_request = proxy.request(request.method, request.url, request.headers);
  proxy_request.addListener('response', function (proxy_response) {
    proxy_response.addListener('data', function(chunk) {
      response.write(chunk, 'binary');
    });
    proxy_response.addListener('end', function() {
      response.end();
    });
    response.writeHead(proxy_response.statusCode, proxy_response.headers);
  });
  request.addListener('data', function(chunk) {
    proxy_request.write(chunk, 'binary');
  });
  request.addListener('end', function() {
    proxy_request.end();
  });
}).listen(8080);

在发出大量请求后失败:

net.js:695
        self.fd = socket(self.type);
                  ^
Error: EMFILE, Too many open files
    at net.js:695:19
    at dns.js:171:30
    at IOWatcher.callback (dns.js:53:15)

OSX 10.6上的节点0.4.2

2 个答案:

答案 0 :(得分:8)

您可能在操作系统中打开了(默认)已打开文件的最大值(对于Linux,它是1024),特别是如果您正在执行大量请求。例如,在Linux中,您可以使用ulimit命令增加此资源限制:

ulimit -n 8192

答案 1 :(得分:3)

在这里复活旧帖子但是我想为Ubuntu添加我自己的答案(无法使ulimit命令工作:s):

$ sudo vim  /etc/security/limits.conf

添加以下内容:

SOME_USER hard nofile SOME_NUMBER
SOME_USER soft nofile SOME_NUMBER

将SOME_USER替换为您的用户。将SOME_NUMBER替换为高于导致问题的限制的数字。

$ sudo vim /etc/pam.d/common-session

添加以下内容:

session required pam_limits.so

重新启动你的机器并解决问题:)。