当前位置: 首页 > 面试题库 >

Node.js + Express:应用程序将无法在端口80上开始监听

仲孙疏珂
2023-03-14
问题内容

我创建并启动一个这样的应用程序:

express -s -t ejs
npm install express
npm install ejs
node app.js

并且可以正常工作(在端口3000上)。但是,当我将端口更改为80时,运行node app.js输出如下:

node.js:198
throw e; // process.nextTick error, or 'error' event on first tick
          ^
TypeError: Cannot call method 'getsockname' of null
at HTTPServer.address (net.js:746:23)
at Object.<anonymous> (/var/www/thorous/app.js:35:67)
at Module._compile (module.js:432:26)
at Object..js (module.js:450:10)
at Module.load (module.js:351:31)
at Function._load (module.js:310:12)
at Array.<anonymous> (module.js:470:10)
at EventEmitter._tickCallback (node.js:190:26)

这在我的笔记本电脑上也有效,但在端口80打开的Amazon EC2实例上无效。可以找出问题所在。有小费吗?


问题答案:

您是否以root用户身份启动应用程序?因为较低的端口号需要root特权。也许sudo节点app.js可以工作吗?

但是,您不应使用root用户特权在端口80上运行任何node.js应用程序!决不!

我的建议是在前端运行nginx作为对在端口3000上运行的node.js应用程序的反向代理



 类似资料:
  • 问题内容: 我正在安装了Node.js的Amazon EC2上运行Debian的实例。如果我运行下面的代码: 我得到下面的输出,它告诉我还有另一个进程正在监听端口80: 现在,当我检查是否有一个进程在端口80上侦听某个进程(以root身份出现,以防任何东西被隐藏)时: 我得到以下输出,它告诉我在端口80上没有监听: 我应该注意,如果这有所作为,那么debian会将80端口作为入站规则打开。 我的问

  • 问题内容: 我无法在端口80上启动应用程序。 我已经在本地计算机(使用我的IDE和本地服务器)上尝试过,没有运气。 我检查了其他类似的帖子,并确保我在具有root用户的服务器上运行jar。 这是错误: 问题答案: 在Linux上,只能由root用户打开低于1024的端口,因此默认情况下限制端口80 如果要在80端口上发布应用,则需要将请求从80端口重定向到要运行springapp(例如8080)端

  • 问题内容: 我的目标是在端口80上运行Node.js。这是因为我发现node.js被某些网络阻止,这些网络不允许来自任何其他端口的流量。 看来最好的方法是通过Node.js代理Apache。我已经尝试使用node-http- proxy 来做到这一点,但是我没有任何运气。 我正在使用的代码在这里: 但是我一直收到端口80的错误“地址正在使用”。我一定做错了。 如何使用node-http-proxy

  • 本文向大家介绍如何用Node监听80端口?相关面试题,主要包含被问及如何用Node监听80端口?时的应答技巧和注意事项,需要的朋友参考一下 这题有陷阱!在类Unix系统中你不应该去监听80端口,因为这需要超级用户权限。因此不推荐让你的应用直接监听这个端口。 目前,如果你一定要让你的应用80端口的话,你可以有通过在Node应用的前方再添加一层反向代理(例如nginx)来实现,如下图。否则,建议你直接

  • 有人能解释一下如何在不指定端口的情况下在端口80上运行我的reactJS应用程序吗 目前它在www.mydomain.com:3001工作,但我希望它是可见的,当我去www.mydomain.com 我在创建-反应-应用文档网站上找不到解决方案,所以我在这里问。 如果我使用 我得到错误的东西已经使用端口80(我没有指定PORT=80) 谢啦

  • 我正在寻找一种在端口80上部署Play-Framework-1.0应用程序的方法。因此,首先,我使用“dist”命令生成zip文件,然后将其解压缩。当我运行命令启动应用程序时(),我得到以下错误: 此外,在真正的服务器中,已经安装了Apache。所以我想知道,这是否会成为一个问题。 谢谢