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

このメソッドは適切ですがtrue、pub.keyがホストにコピーされたときに返されます。キーなしで2つのデバイス間でsshが接続可能かどうかを確認する必要があります。

sshdがリモートで実行されているかどうかを確認したいだけです。

4

1 に答える 1

31

ssh経由でホストに接続できるかどうかを確認したいだけの場合は、ポート22が開いているかどうかを確認するだけです。これにはさまざまな方法があります。

nmapの使用(ローカルホストをターゲットホストに置き換えます):

$ 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.

ただし、このようなアプローチはさまざまな理由で望ましくありません。保証される唯一の方法は、質問で示したように実際の接続を確立することです。

于 2012-08-15T12:22:41.333 に答える