96

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でリッスンしているプロセスがあるかどうかを確認すると(何かが隠されている場合に備えてルートとして):

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 でブロックされているのはなぜですか? コードを正しく実行するには、どのような手順を実行する必要がありますか?

4

8 に答える 8

74

ポート 80 で実行する代わりに、ポート 80 をアプリケーションのポート (>1024) にリダイレクトできます。

iptables -t nat -I PREROUTING -p tcp --dport 80 -j REDIRECT --to-port 3000

これは、アプリケーションがポート 3000 で実行されている場合に機能します。

于 2013-09-22T22:48:00.603 に答える
22

簡単な答え: 次を使用して、そのポートへのノード アクセスを許可できます。

setcap 'cap_net_bind_service=+ep' /path/to/nodejs

長い答え

編集:

新しいノード バージョンでは動作しない可能性があります

于 2014-11-24T01:22:10.463 に答える
0

同じエラーが発生し、sudo を使用してアプリケーションを実行しようとしましたが、うまくいきました。

須藤なし

mansi@mansi:~/NodePractice$ node myFirst.js 
events.js:141
      throw er; // Unhandled 'error' event
      ^

Error: listen EACCES 0.0.0.0:80
    at Object.exports._errnoException (util.js:870:11)
    at exports._exceptionWithHostPort (util.js:893:20)
    at Server._listen2 (net.js:1224:19)
    at listen (net.js:1273:10)
    at Server.listen (net.js:1369:5)
    at Object.<anonymous> (/home/mansi/NodePractice/myFirst.js:6:4)
    at Module._compile (module.js:410:26)
    at Object.Module._extensions..js (module.js:417:10)
    at Module.load (module.js:344:32)
    at Function.Module._load (module.js:301:12)

そしてsudoで

mansi@mansi:~/NodePractice$ sudo node myFirst.js 
^C
于 2018-01-14T00:15:46.650 に答える