我正在安装了Node.js的Amazon EC2上运行Debian的实例。如果我运行下面的代码:
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.<anonymous> (/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中将其阻止?我应该采取什么步骤才能使代码正确运行?
错误代码EACCES表示您没有适当的权限在该端口上运行应用程序。在Linux系统上,低于1024的任何端口都需要root用户访问权限。
EACCES