本地虚拟机上的linux 上搭建nodejs ,并开启一个端口3000 服务,本地访问,怎么访问不了?

本地虚拟机上的linux 上搭建nodejs ,并开启一个端口3000 服务,本地访问,怎么访问不了?,第1张

看看防火墙策略

iptables -nvL

如果有策略,清空再试。

红帽子、FC、centos系列用service iptables stop

其他版本用iptables -P INPUT ACCEPT &&iptables -F

由于linux的系统限制,普通用户是无法打开1024以下端口的,这里面就包括http的默认端口80,这就使得很多用户使用root权限来执行node,这带来了不可预计的安全问题,所以这并不是一个好办法。

其实我们可以使用iptables的端口转发功能来解决这个问题:

1,首先将node的主程序绑定到高于1024端口,比如8090,这样普通用户就可以启动这个http server了,只不过不是在默认的80端口上监听;

2,配置iptables将80端口转发到8090上,如下命令:

#iptables -t nat -A PREROUTING -p tcp --dport 80 -j REDIRECT --to-port 8090

该命令的意思就是在iptable中添加一条端口转发规则,如果删除该规则,重新绑定,则先查找出:

#iptables --line-numbers --list PREROUTING -t nat

然后使用行号删除:

#iptables -t nat -D PREROUTING 行号

3,记得添加8090端口到iptables的INPUT ACCEPT规则中

#iptables -I INPUT -p tcp --dport 8090 -j ACCEPT

4,第2步和第3步添加的这些规则,都是临时性的,重启服务器之后就无效了,所以需要保存起来

#/sbin/service iptables save

端口转发配置完成

————————————————

版权声明:本文为CSDN博主「newborn2012」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。

原文链接:https://blog.csdn.net/newborn2012/article/details/23860687


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/yw/7301882.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-04-04
下一篇2023-04-04

发表评论

登录后才能评论

评论列表(0条)

    保存