我正在测试一个应用程序(希望在heroku上运行,但在本地也有问题)。当它运行http.Server.listen()时,它给我一个EACCES错误-但它只发生在一些端口上。

我在本地运行:

joe@joebuntu:~$ node
> var h = require('http').createServer();
> h.listen(900);
Error: EACCES, Permission denied
    at Server._doListen (net.js:1062:5)
    at net.js:1033:14
    at Object.lookup (dns.js:132:45)
    at Server.listen (net.js:1027:20)
    at [object Context]:1:3
    at Interface.<anonymous> (repl.js:150:22)
    at Interface.emit (events.js:42:17)
    at Interface._onLine (readline.js:132:10)
    at Interface._line (readline.js:387:8)
    at Interface._ttyWrite (readline.js:564:14)

我没有在端口900(或我尝试过的其他20个端口中的任何一个)上运行任何东西,因此这应该可以工作。奇怪的是,它确实在某些端口上工作。例如,端口3000可以正常工作。

是什么导致了这种情况?

更新1:

我发现在我的本地计算机上,EACCES错误出现了,因为我必须以root身份运行node才能绑定到那些特定的端口。我不知道为什么会发生这种情况,但是使用sudo可以修复它。然而,这并不能解释我如何在Heroku上修复它。没有办法在Heroku上以root身份运行,所以我怎么能在端口80上监听?


当前回答

有时这是因为网点配置不好。例如:require(“dotenv”)。在你的应用程序中间件中配置没有(),或者可能是你用错误的语法写了你的端口号,比如你写了:而不是=,或者在端口号中添加了一些其他符号。

其他回答

对我来说,这只是.env文件中的一个错误。我删除了每行末尾的逗号,问题就解决了。

之前:

HOST=127.0.0.1,

后:

HOST=127.0.0.1

在工作站上运行

作为一般规则,没有根权限的进程不能绑定到1024以下的端口。

所以尝试一个更高的端口,或者通过sudo以更高的权限运行。在使用进程绑定到低端口后,可以降级特权。Setgid和process.setuid。

在heroku上奔跑

当你在heroku上运行你的应用程序时,你必须使用port环境变量中指定的端口。

参见http://devcenter.heroku.com/articles/node-js

const server = require('http').createServer();
const port = process.env.PORT || 3000;

server.listen(port, () => console.log(`Listening on ${port}`));

对我有用的是,

解决方法1:我发现我的.env文件不正确。你不应该在变量之间使用','或';'分隔符。

解决方案2:如果它是一个react应用程序,确保你在客户端目录下,并且你没有试图在服务器目录下运行你的react应用程序(不是给你一个错误,而是解决问题)。

我有一个类似的问题,它拒绝在端口8080上运行,但也拒绝任何其他端口。

事实证明,这是因为环境。它读取的本地文件在变量名后面包含注释,例如:

PORT=8080 # The port the server runs at

它这样解释它,试图使用端口“8080 #服务器运行的端口”,这显然是一个无效的端口(-1)。 删除注释完全解决了这个问题。

使用Windows 10和Git Bash。


我知道这不是这里描述的问题,但它可能会帮助到一些人。我在这个问题上寻找问题的答案,所以…也许?

#窗口

另一个原因——也许你的端口已经被某些原因排除在外了。

所以,尝试在管理员权限下打开CMD(命令行)并运行:

Net stop winnat Net start winnat

对我来说,这就足够了。

解决方案:https://medium.com/@Bartleby/ ports-the-- availal-listen-tcp -0-0-0-3000-165892441b9d