6

以下问题已部分回答,请参阅下面的解决方案部分。所以我发布这个部分是为了帮助别人,而且因为我的解决方案还没有真正解决问题。

问题

因此,问题是为什么以下技术(使用 python 的平台和套接字库)给出的主机名会根据您连接的路由器给出不同的主机名,以及为什么它与计算机名和本地主机名也不同。顺便说一下,这也是非常特定于 mac 的。

首先,我使用的是配备 High Sierra 10.13.6 的 MacBook pro 2015 型号。我使用终端并执行以下操作:

import platform
platform.node()

根据分配给 MacBook 的 IP 地址,这给了我类似“192-168-1-4.tpgi.com.au”的信息。不同的路由器给出不同的结果。我也得到了类似的结果

import socket
socket.gethostname()

它再次返回类似“192-168-1-4.tpgi.com.au”的内容。

其次,我承认回答类似问题 4271740/how-can-i-use-python-to-get-the-system-hostname 的文章

但是,这个问题略有不同,毕竟据我的应用程序的用户所知,主机名应该是他们可以在系统设置中看到的主机名,这实际上是不同的。如果我运行:

sudo scutil --get LocalHostName

我得到了系统设置中显示的名称(在共享下,它相当容易混淆地显示计算机名称和本地主机名,它们也可能不同)。本地主机名与限定语句一起显示:

您本地网络上的计算机可以访问您的计算机: foo.local

这一切都是问题的原因是我的应用程序使用了主机名,这与mac上的本地主机名和计算机名不同。这个主机名随后会出现在我们的用户界面中,当然,当它的格式为“192-168-1-4.tpgi.com.au”时,它对于识别用户的计算机没有帮助。用户很可能希望看到他们的计算机名称,因为这是可见的。在 Mac 上,主机名是不可见的,它可以通过命令设置或获取,但如果我们的用户遇到这个问题,它不太可能是我们的用户自然会想到的。

解决方案

所以问题与我相信如何开箱即用地设置mac有关。主机名可以在 Mac 上通过终端中的以下命令进行查询:

hostname
192-168-1-4.tpgi.com.au

这将返回实际用于解析 IP 地址的主机名。正如我上面提到的,这与使用我们的应用程序时容易引起混淆的计算机名称不匹配。当我运行以下查询时,我发现了这一点。

sudo scutil --get HostName
HostName: not set

因此,我使用以下命令将主机名设置为我可以识别的机器名称,如下所示

sudo scutil --set HostName foo

现在,当我运行以下命令时,我得到了我和其他技术含量较低的用户所期望的结果。

import socket
socket.gethostname()
foo

import platform
platform.node()
foo

最后只是为了更好的衡量,我从终端跑了

hostname
foo

结论

好的,所以虽然我已经写到我找到了一个解决方案,但它并不是我真正需要的解决方案,问题是我需要显示用户设置的计算机名称并且将识别而不是主机名。由于我使用的是 python,我真的很希望能够找到一个用于 mac 的 python 命令,它可以找到计算机名称,而不是主机名。因此,如果有人知道这样做的干净且可持续的方式(我宁愿不必运行 shell 命令并解析其输出),我将非常感激!如果相同的命令(或函数)也可以在 Windows 和 linux 等其他操作系统类型上运行,那就太好了,但我已经接受这是一个 mac 的东西,至少据我所知。

同时,如果其他人遇到类似问题,我希望以上内容有所帮助:)

谢谢!

4

1 回答 1

1

我可以确认此错误以及解决方法,并注意它不会立即生效,无需重新启动,但 DNS 缓存需要过期(或过期)才能完全生效。

我遇到了同样的问题,它影响任何非 fqdn 解析,而不仅仅是本地机器名称。例如nslookuporping似乎可以完美地工作,而只有 pythonsocket.getfqdn()并且socket.gethostbyname()似乎被破坏了。我的系统同时具有 IPv4 和 IPv6 堆栈,这可能与该问题有关。

所以解决方法看起来像:

sudo scutil --set HostName `hostname`

必须hostname返回 FQDN 才能使其正常工作。

在我的情况下,就像这样foo.lan,在这样做之后,python 开始能够解析名称,例如foo.labbar.lan

因为操作系统本机工具不受此影响,所以我最终创建了一个与 MacOS 相关的 Python 错误,因为我们不应该被迫使用上述解决方法来使其工作。

https://bugs.python.org/issue35164 <--让我们在这里跟进。

于 2018-11-04T16:41:28.327 回答