从我到目前为止在教程中读到的内容来看,可选hostname
参数server.listen(port[, hostname][, backlog][, callback])
始终是127.0.0.1
(环回),0.0.0.0
(监听每个可用的网络接口,默认选项),或者服务器可用的实际IP地址之一.其他一切都会给出一个Error: listen EADDRNOTAVAIL
.那是全貌吗?(我相信主机名在技术上与IP不同......)
我无法从文档中找到太多关于它的内容......
因此,您需要一个可解析的DNS主机名才能使用.有关快速示例,我编辑了该/etc/hosts
文件以包含以下条目:
... 127.0.0.1 MyTestDnsHostName.local
然后我用旧的刷新了解析器缓存,dscacheutil -flushcache
并在一个简单的Node.js服务器中使用了下面的代码.
var http = require('http') , PORT = 8080; function handleRequest( request, response ){ response.end( 'It Works!' ); } var server = http.createServer( handleRequest ); server.listen( PORT, "MyTestDnsHostName.local", 34, function(){ console.log( "Server listening on port:%s", PORT ); });
确实有效.
该错误EADDRNOTAVAIL
意味着它可以解析但不可用; 现在,为了能够绑定它,它也应该是可绑定的(可用的).
你可以做一个lsof -i TCP
检查它绑定的位置.
但是,我不明白为什么你必须在其他地方绑定服务器; 绑定到环回是最佳实践.
是的,所以这实际上是一个安全漏洞; 如果你将它绑定到所有可用的接口0.0.0.0
,你基本上说的是Listen to every available network interface there is
.这可能会带来安全漏洞,因为它可能绑定到您不希望它的适配器; 在部署RoR应用程序时,我已经掌握了这方面的第一手经验.
该0.0.0.0/0
子网是说的一个非常奇特的方式:these are all the network interfaces I have on this computer
,而127.0.0.1
始终是本地唯一接口.如果将其绑定到此,则可以解决相当多的安全问题.其中一个可能是"黑客"试图在所有接口上附加一个监听器,如果你没有一个非常严格的防火墙,在某个地方或另一个地方,可能会出现泄漏.
这不是一个规则,而只是一种最佳实践.
PS:代码是我从Modulus的博客中摘取的片段; 如果我想尝试一下,它会很快.