更新:原来唯一的问题是我在阻止某些端口的防火墙后面,但不是8000.
编辑: TL; DR:无法远程连接到端口9000,但端口8000正常,我不知道原因:(
我已经在端口 8000 上运行了这个node.js应用程序,在端口 9000 上运行了另一个(http-proxy)。
在我的机器上运行它们很好,但是当我把它们放在服务器上时我遇到了一些问题( EC2 实例 - 我确实打开了Web控制台安全组中的端口 [ 1] )。该应用程序工作正常,但我无法从外部连接到代理。我尝试在服务器上$ telnet localhost 9000
并连接,所以我想这是一个好兆头。
我注意到的另一件事是,如果我尝试单独运行应用程序,我会得到相同的结果,即:8000 - OK,9000 - NOTOK:<。 但是,如果我将代理使用的端口从9000更改为8000,则可以正常工作。如果我切换端口,即应用程序:9000和代理:8000,我可以连接到代理,但不能连接到应用程序。我也尝试了其他数字,但这也无法解决。
我想有一些非常愚蠢的东西与应用程序本身无关,而且我很遗憾,但是我不能指责它,所以有谁知道为什么这个设置不起作用?
server.js
var express = require('express.io');
var app = module.exports = express();
require('./proxy');
app.http().io();
app.listen(8000);
// ...
的proxy.js
var httpProxy = require('http-proxy');
var url = require('url');
httpProxy.createServer(function(req, res, proxy) {
// ...
proxy.proxyRequest(req, res, {
host: destination.host,
port: 80
});
}).listen(9000);
$ netstat -pln | grep node
输出
tcp 0 0 0.0.0.0:9000 0.0.0.0:* LISTEN 1487/node
tcp 0 0 0.0.0.0:8000 0.0.0.0:* LISTEN 1487/node
安全组规则
答案 0 :(得分:3)
事实证明,该问题与应用程序或EC2实例设置完全无关。
我在测试时遇到的网络阻塞了一些端口。这就是为什么当将代理移动到端口8000
时,它工作正常,但在9000
或其他任何我尝试过的随机数不是。 D'哦!