其实我们可以使用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
用Socket实现的一个端口测试程序
var net = require('net'),socket = net.Socket/*测试端口
*/
var testPort = function(port,host,cb){ var nsk = new socket()
nsk.setTimeout(5000)//设置连接超时时间 5s
nsk.on('connect',function(){//连接状态
nsk.destroy()//销毁
cb(port,'open')
})
.on('timeout',function(){//连接超时
nsk.destroy()
cb(port,'timeout')
})
.on('error',function(){//连接错误
nsk.destroy()
cb(port,'closed')
})
nsk.connect(port,host)//执行连接
}