ssh -q -o "BatchMode=yes" [email protected] "echo 2>&1" && echo "OK" || echo "NOK"
を実行するかどうかを確認する方法この方法は適しているがpub.keyがホストにコピーされるとき、それはtrue
を返します。 sshがキーのない2つのデバイス間で接続可能かどうかを確認する必要があります。sshdはリモートマシン上で
sshdがリモートで実行されているかどうかを確認したいだけです。
ssh -q -o "BatchMode=yes" [email protected] "echo 2>&1" && echo "OK" || echo "NOK"
を実行するかどうかを確認する方法この方法は適しているがpub.keyがホストにコピーされるとき、それはtrue
を返します。 sshがキーのない2つのデバイス間で接続可能かどうかを確認する必要があります。sshdはリモートマシン上で
sshdがリモートで実行されているかどうかを確認したいだけです。
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.
しかしながら、このようなアプローチは、様々な理由のために望ましくありません。唯一の保証された方法は、あなたの質問に示されているように実際の接続を確立することです。
'nmap'がこれに適しています。 sshを含む、システム上のすべてのオープンポートを一覧表示します。 – fduff