尽管没有其他进程阻塞端口,但Node.js应用程序无法在端口80上运行。

20 浏览
0 Comments

尽管没有其他进程阻塞端口,但Node.js应用程序无法在端口80上运行。

我在Amazon EC2上运行了一个Debian实例,并安装了Node.js。如果我运行下面的代码:

http = require('http');
http.createServer(function (request, response){
  response.writeHead(200, {'Content-Type':'text/plain'});
  response.end('Hello World\n');
}).listen(80);
console.log("Running server at port 80");

我得到以下输出,告诉我在端口80上有另一个进程正在监听:

Running server at port 80
events.js:72
        throw er; // Unhandled 'error' event
              ^
Error: listen EACCES
    at errnoException (net.js:901:11)
    at Server._listen2 (net.js:1020:19)
    at listen (net.js:1061:10)
    at Server.listen (net.js:1127:5)
    at Object. (/home/admin/nodetests/nodetest.js:6:4)
    at Module._compile (module.js:456:26)
    at Object.Module._extensions..js (module.js:474:10)
    at Module.load (module.js:356:32)
    at Function.Module._load (module.js:312:12)
    at Function.Module.runMain (module.js:497:10)

现在,当我检查是否有进程在端口80上监听时(以root身份以防有隐藏的内容),我使用以下命令:

netstat -tupln

我得到以下输出,告诉我在端口80上没有任何监听的进程:

Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN      1667/sshd       
tcp6       0      0 :::22                   :::*                    LISTEN      1667/sshd

我应该注意到,Debian已将端口80作为入站规则打开,如果有什么区别的话。

我的问题是:我做错了什么?为什么我无法识别监听端口80的进程?为什么Debian中被阻止了?我应该采取哪些步骤来正确运行代码?

0