ssh -q -o "BatchMode=yes" user@host "echo 2>&1" && echo "OK" || echo "NOK"
这种方法是合适的,但是当pub.key被复制到主机时它返回true.
我需要看看一个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.