web-dev-qa-db-ja.com

SSHがこれらのコマンドの最後でハングするのはなぜですか、どうすれば終了させることができますか?

私はこれを実行します:

ssh -t -vvv -i ~/.ssh/druid-keypair -o StrictHostKeyChecking=no ubuntu@${INSTANCE_ADDRESS} <<EOI

# Setup Oracle Java
...

# Install dependencies - mysql must be built from source, as the 12.04 apt-get hangs
export DEBIAN_FRONTEND=noninteractive
Sudo debconf-set-selections <<< 'mysql-server-5.5 mysql-server/root_password password diurd'
Sudo debconf-set-selections <<< 'mysql-server-5.5 mysql-server/root_password_again password diurd'
Sudo apt-get -q -y -V --force-yes --reinstall install mysql-server-5.5

echo "ALL DONE with druid environment setup!"
exit
EOI

注:私はsshで-tを付けて、または付けずに試してみました。

-vvvからのデバッグ出力は次のとおりです。

...
ldconfig deferred processing now taking place
ALL DONE with druid environment setup!
debug1: client_input_channel_req: channel 0 rtype exit-status reply 0

そして、プロセスは永遠にそこにあります。 sshコマンドが終了しないのはなぜですか?私は-tありとなしで試してみました、そして出口ありとなしで試してみました。違いはありません:(

更新:スクリプトの最後に「jobs」と入力すると、次のように表示されます。

JOBS:
[1]-  Running                 Nohup bin/zookeeper-server-start.sh config/zookeeper.properties 2>&1 > /dev/null &
[2]+  Running                 Nohup bin/kafka-server-start.sh config/server.properties 2>&1 > /dev/null &

これらのサービスを実行しても、sshセッションを終了するにはどうすればよいですか?

更新:これらのプロセスを手動で否認しました。事はまだ存在しません。 WTFの仲間?

更新:行ごとに実行すると、2つのコマンドがCRを押さないとシェルに戻りません。

Nohup bin/zookeeper-server-start.sh config/zookeeper.properties &
Nohup bin/kafka-server-start.sh config/server.properties &
10
rjurney

通常、バックグラウンド接続がまだ開いている場合、SSHターミナルセッションはハングします。バックグラウンド接続とは、次のようなことを意味します。

  • X11ウィンドウ転送
  • STDOUTおよびSTDERR

ハングしたSSHターミナルで~#と入力して、ハングしたSSHセッションでまだアクティブな接続を確認します。

スクリプトが、気づかなかったセッションを開いている可能性があります。または、.profile(または.bashrcなど)などのリモートマシンの端末設定に、セッションを確立する何かが含まれている可能性があります。頑張ってハンティング!

ちなみに、OpenSSHクライアントが提供する他のエスケープシーケンスの一部も役立つ場合があります。

Supported escape sequences:
  ~.  - terminate connection (and any multiplexed sessions)
  ~B  - send a BREAK to the remote system
  ~C  - open a command line
  ~R  - Request rekey (SSH protocol 2 only)
  ~^Z - suspend ssh
  ~#  - list forwarded connections
  ~&  - background ssh (when waiting for connections to terminate)
  ~?  - this message
  ~~  - send the escape character by typing it twice
(Note that escapes are only recognized immediately after newline.)

もう1つ、SSHでコマンドを実行してすぐに終了する場合、つまり、リモートターミナルセッションを使用しない場合は、-fオプションをsshに使用できます。 。これにより、SSH接続がバックグラウンドジョブになります。

22
padub