4

我在 Mac OS X 上使用 nc 实用程序时遇到了一个小问题,我经常使用该实用程序作为快速而肮脏的解决方案来检查端口是否打开以及守护程序正在运行的版本。

前几天我们部署了一套新的计算机,我想验证它们运行的​​是什么版本的 sshd,而不必离开我的椅子。

这是我运行的命令和结果输出:

$ for i in {183..200}; do echo "hello" | nc -n -w 2 -v 10.120.113.$i 22; done
Connection to 10.120.113.183 22 port [tcp/*] succeeded!
SSH-2.0-OpenSSH_5.9
Protocol mismatch.
nc: connect to 10.120.113.184 port 22 (tcp) failed: Connection refused
^C
$

它在 183 上找到第一台机器并返回守护程序版本,它看起来不像 sshd 在 184 上运行,但是当它达到 185 时它就停止了,我必须用 ctrl+c 杀死它。

据我了解,nc 的手册页在使用“-w”开关时应该超时,但事实并非如此。它来自多台机器的相同问题。

这仅仅是我误解手册页的情况吗?如果没有收到任何响应,还有其他方法可以让 nc 在 X 秒后超时吗?有没有其他方法可以使用 Mac OS X 中的内置工具来做到这一点?

我也试过只用'-z'开关运行nc,结果相同。这些机器被放置在我们的生产中,所以我不允许安装任何 3rd 方应用程序,如 nmap。

Platform: Mac OS X 10.8.4
Executable: /usr/bin/nc

抱歉,如果此问题已得到解答,我进行了搜索,但找不到任何解决方案。

4

2 回答 2

14

我相信您正在寻找-G选择。从手册页:

-G conntimeout TCP 连接超时,以秒为单位。

-w用于设置连接的超时时间。-G选项用于设置连接的超时时间。这应该给你你想要的

nc -n -G 2 -v xxx.xxx.xxx.xxx 22
于 2016-02-01T22:42:29.507 回答
2

我在运行 10.8.4 的 Mac 上尝试了这个,大约 6 分钟后它看起来像:

andys-MacBook-Pro:EquipDB uw$ for i in {183..200}; do echo "hello" | nc -n -w 2 -v 10.120.113.$i 22; done
nc: connect to 10.120.113.183 port 22 (tcp) failed: Operation timed out
nc: connect to 10.120.113.184 port 22 (tcp) failed: Operation timed out
nc: connect to 10.120.113.185 port 22 (tcp) failed: Operation timed out
nc: connect to 10.120.113.185 port 22 (tcp) failed: Operation timed out

所以我的超时了,但只需要相当长的时间。

嗯......我认为我的测试毫无意义,因为我永远不会真正连接到某些东西,因为我不在你的网络上。但我确实看到了这个:

-w # => # 秒后超时

请注意,-w 还设置网络不活动超时。这在标准输入关闭之前没有任何影响,但是如果在接下来的几秒钟内没有任何进一步的来自网络的到达,netcat 会尝试再次读取网络以进行良好的测量,然后关闭并退出。现在有很多网络服务接受少量输入并返回大量输出,例如 Gopher 和 Web 服务器,这就是 netcat 被写入“阻止”网络保持开放而不是保持开放的主要原因。比标准输入。以这种方式处理超时可以使网络服务器具有统一的行为,这些服务器在被告知之前不会自行关闭。

这适用于最终的网络读取,但不适用于连接。

如果我理解这一点,它只会在连接后超时,因为我的从来没有连接过,它只是有一个与 -w 无关的内置超时?在这里找到,有用吗?

于 2013-09-02T18:13:23.210 回答