ssh -q -o "BatchMode=yes" user@host "echo 2>&1" && echo "OK" || echo "NOK"
此方法是合适的,但它会true
在 pub.key 复制到主机时返回。我需要查看 ssh 是否可以在没有密钥的两个设备之间连接。
只是想检查 sshd 是否正在远程运行。
如果您只想检查是否可以通过 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.
然而,由于各种原因,这种方法是不可取的。唯一有保证的方法是建立实际连接,如您在问题中所示。