ฉันใช้งานอินสแตนซ์ของ Debian บน Amazon EC2 ที่ติดตั้ง 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.<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
ฉันควรทราบว่าเดเบียนมีพอร์ต 80 เปิดเป็นกฎขาเข้าหากสิ่งนั้นสร้างความแตกต่าง
คำถามของฉันคือฉันทำอะไรผิด? ทำไมฉันไม่สามารถระบุกระบวนการฟังพอร์ต 80 ได้? เหตุใดจึงถูกบล็อกใน Debian ฉันควรทำขั้นตอนใดเพื่อให้โค้ดทำงานอย่างถูกต้อง