リモートホストでパスワードなしのSSHを介して接続するスクリプトを実行しています。タイムアウトを設定したいので、リモートホストの実行に無限の時間がかかっている場合は、そのsshセッションから出て、shスクリプトの他の行を続行します。
それを行う方法についてのアイデアはありますか?
ssh
セッションの滞在時間を増やす」だけにリダイレクトした場合(質問「SSH接続タイムアウトを増やす方法」)、これは間違った場所です。答えはssh-timeoutに関するこのリンクにあります。
リモートホストでパスワードなしのSSHを介して接続するスクリプトを実行しています。タイムアウトを設定したいので、リモートホストの実行に無限の時間がかかっている場合は、そのsshセッションから出て、shスクリプトの他の行を続行します。
それを行う方法についてのアイデアはありますか?
ssh
セッションの滞在時間を増やす」だけにリダイレクトした場合(質問「SSH接続タイムアウトを増やす方法」)、これは間違った場所です。答えはssh-timeoutに関するこのリンクにあります。
回答:
ssh -o ConnectTimeout=10 <hostName>
10は秒単位の時間です。このタイムアウトは、接続の作成にのみ適用されます。
-o ConnectTimeout
およびを使用し-o BatchMode=yes -o StrictHostKeyChecking=no
ます。
ConnectTimeoutはスクリプトがハングするのを防ぎ、BatchModeはHost unknownでハングするのを防ぎます。YESがknown_hostsに追加され、StrictHostKeyCheckingがフィンガープリントを自動的に追加します。
****注****「StrictHostKeyChecking」は、ホストを信頼する内部ネットワークのみを対象としています。SSHクライアントのバージョンによっては、「指紋を追加してよろしいですか?」が原因でクライアントが無期限にハングアップすることがあります(主に、AIXで実行されている古いバージョン)。ほとんどの最新バージョンでは、この問題は発生しません。複数のホストでフィンガープリントを処理する必要がある場合は、puppet / ansible / chef / salt / etcなどのある種の構成管理ツールでknown_hostsファイルを維持することをお勧めします。
-o StrictHostKeyChecking=no
質問に対応しないだけでなく、セキュリティを重視するのはひどい考えです。そもそもそれがSSHを使用している理由かもしれません。
StrictHostKeyChecking=no
セキュリティを気にする場合は使用しないでください。@Doug:スクリプトはハングしません-初めて手動でリモートホストにsshすることを要求するだけなので、ホストを知ることができます。しかし、それはMITM攻撃からあなたを守ります。現状では非常に危険なアドバイスなので、この回答を編集してこれを反映してください。そして、それも要求されませんでした。
これを試して:
timeout 5 ssh user@ip
timeoutはsshコマンド(args付き)を実行し、sshが5秒後に戻らない場合はSIGTERMを送信します。タイムアウトの詳細については、このドキュメントをお読みください: 参照してください http //man7.org/linux/man-pages/man1/timeout.1.html
または、sshのパラメーターを使用できます。
ssh -o ConnectTimeout=3 user@ip
brew install coreutils
てから使用してください。gtimeout
timeout 3s ssh user@server 'sleep 5; echo blarg >> /tmp/blarg'
これにより、SSHクライアント側のプロセスが強制終了されますが、リモートサーバーでは/ tmp / blargが引き続き変更されます。つまり、リモートサーバーでCPUを集中的に使用する暴走ジョブを実行している場合、プロセスがリークします。
フラグと接続することもできます
-o ServerAliveInterval = <秒>そのため、SSHクライアントは
<secs>
、接続を維持するために、毎秒nullパケットをサーバーに送信します。Linuxでは、これはでグローバルに、/etc/ssh/ssh_config
またはユーザーごとに設定することもできます~/.ssh/config
。
他のすべてが失敗した場合(timeout
コマンドがないことを含む)、このシェルスクリプトの概念は機能します。
#!/bin/bash
set -u
ssh $1 "sleep 10 ; uptime" > /tmp/outputfile 2>&1 & PIDssh=$!
Count=0
while test $Count -lt 5 && ps -p $PIDssh > /dev/null
do
echo -n .
sleep 1
Count=$((Count+1))
done
echo ""
if ps -p $PIDssh > /dev/null
then
echo "ssh still running, killing it"
kill -HUP $PIDssh
else
echo "Exited"
fi
まあ、nohupを使用して、「ノンブロッキングモード」で実行しているものを実行できます。そのため、実行、実行、または終了するはずだったものをチェックし続けることができます。
nohup ./my-script-that-may-take-long-to-finish.sh& ./check-if-previous-script-ran-or-exit.sh
echo "スクリプトは2011年2月15日午前9:20に終了しました"> /tmp/done.txt
したがって、2番目のファイルでは、ファイルが存在するかどうかを確認するだけです。