如何检查sshd是否在远程计算机上运行

时间:2012-08-15 12:06:52

标签: linux bash shell

ssh -q -o "BatchMode=yes" user@host "echo 2>&1" && echo "OK" || echo "NOK"

此方法适用,但当pub.key复制到主机时它返回true。 我需要看看两个没有密钥的设备之间是否可以连接ssh。

只想检查sshd是否正在远程运行。

1 个答案:

答案 0 :(得分:26)

如果您只想检查是否可以通过ssh连接主机,只需检查端口22是否打开即可。有各种方法可以解决这个问题。

使用nmap(将localhost替换为目标主机):

$ nmap -p22 localhost

Starting Nmap 5.21 ( http://nmap.org ) at 2012-08-15 13:18 BST
Nmap scan report for localhost (127.0.0.1)
Host is up (0.000044s latency).
PORT   STATE SERVICE
22/tcp open  ssh

Nmap done: 1 IP address (1 host up) scanned in 0.04 seconds

在脚本中使用它:

if nmap -p22 localhost -oG - | grep -q 22/open; then 
    echo "OK"
else 
    echo "NOK"
fi

您还可以使用netcat

$ nc -zv localhost 22
Connection to localhost 22 port [tcp/ssh] succeeded!

在脚本中使用它:

if nc -zv localhost 80 2>&1 | grep -q succeeded; then 
    echo "OK"
else 
    echo "NOK"
fi

这是一种快速检查,在大多数情况下都足够了,但它并非万无一失。无法保证在远程端口上侦听的服务实际上是SSH服务器。

您可以尝试虚拟连接并检查返回的标头,例如:

$ echo "dummy" | nc localhost 22
SSH-2.0-OpenSSH_5.9p1 Debian-5ubuntu1
Protocol mismatch.
然而,出于各种原因,这种方法是不合需要的。唯一有保证的方法是建立一个你在问题中显示的实际连接。