1. ホーム
  2. javascript

[解決済み] Node.jsアプリが80番ポートで実行できない(他のプロセスがブロックしていないのに

2023-01-23 17:20:54

質問

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 権が必要です。