ターゲットコンピュータ(OS X El Capitan)に抽出するパスを取得しようとすると、結果はありませんbrew
。/usr/local/bin
# ssh [email protected] -p 2222 which brew
#
トラブルシューティング:
brew
/usr/local/bin/
次の方法で正しく実行してくださいssh
。# ssh [email protected] -p 2222 ls -l /usr/local/bin/brew -rwxr-xr-x 1 vagrant admin 656 Mar 20 10:05 /usr/local/bin/brew # ssh [email protected] -p 2222 /usr/local/bin/brew --version Homebrew 0.9.5 (git revision 3a41; last commit 2016-03-20)
/usr/local/bin
パスには以下が含まれます。# ssh [email protected] -p 2222 echo $PATH /usr/local/sbin:/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin:/opt/X11/bin:/opt/local/bin:/opt/local/sbin
which
それ自体は問題がないようです。# ssh [email protected] -p 2222 which bash /bin/bash
また、マシンにインタラクティブにログインしたときに予想される結果が得られました。
# ssh [email protected] -p 2222 Last login: Sun Mar 20 12:02:55 2016 from 10.0.2.2 osx-pf:~ vagrant$ which brew /usr/local/bin/brew
最後に、
which brew
コマンド置換表現で動作します。# ssh [email protected] -p 2222 echo $(which brew) /usr/local/bin/brew
echo
以前に呼び出すと、which brew
正しい結果が得られます。# ssh [email protected] -p 2222 echo test ; which brew test /usr/local/bin/brew
実行するシェルを明示的に呼び出しても、
which brew
この状況は変わりません。# ssh [email protected] -p 2222 /bin/sh -c "which\ brew" # ssh [email protected] -p 2222 /bin/sh -c "which\ which" /usr/bin/which
しかし、
/bin/sh
(6)の「トリック」を明示的に呼び出すことはもう機能しません。# ssh [email protected] -p 2222 /bin/sh -c "echo\ test\ \;\ which\ brew" test #
which brew
SSHコマンドパラメータで直接実行すると失敗するのはなぜですか?
echo
どの外部コマンドが/bin/echo
正しく表示されますが、PATH
表示されないのですかwhich
? 2つのコマンドを順番に実行すると、2番目のコマンドが最初のコマンドの環境を使用するのはなぜですか?
(6)の文書化されていない解決策を参照せずに環境がロードされていることを確認することは可能ですか?
答え1
ssh [email protected] -p 2222 echo $PATH
ローカルシステムはPATH
ここから印刷されます。ローカルシェルで変数が拡張されるのを防ぐには、変数を引用する必要があります。
ssh [email protected] -p 2222 'echo $PATH'
以下も同様に適用されます。
ssh [email protected] -p 2222 echo $(which brew)
については:
ssh [email protected] -p 2222 echo test ; which brew
which brew
SSHコマンドが終了したら、ローカルシェルで実行します。これがうまくいかない理由は次のとおりです。
ssh [email protected] -p 2222 /bin/sh -c "echo\ test\ \;\ which\ brew"
注:すべてのエスケープ操作を実行する必要はありません。
ここでの問題は、次のようなin(または同様のファイル)brew
に追加することです。PATH
.profile
.bash_profile
ログインシェル始まった。 SSH は、コマンドの実行を指示するのではなく、対話的に実行された場合にのみログインシェルを起動します。 ~からman ssh
:
If command is specified, it is executed on the remote host instead of a login shell
あなたは試すことができます:
ssh [email protected] -p 2222 bash -lc brew
答え2
sshから直接コマンドを実行すると、「ログイン」するのではなく、コマンドを実行するだけです。
一部のシェルスクリプトは、「ログイン」すると実行されます - ~/.bashrc、/etc/profileなど。
which
特に、環境変数の使用は、$PATH
これらのスクリプトのいずれかで設定できます。それがなければ、$PATH
どこwhich
を見るべきかわかりません。
また、期待するバーは提供していません。これはsshに達する前にシェルによって解釈されます。以下と比較してください(シェル拡張の周りの一重引用符を参照)。最初はローカルホスト名を取得し、エコーのためにリモートホストに送信します。 2番目は(文字通り)リモートシェルに転送され、拡張されます。ssh [email protected] -p 2222 echo $(which brew)
$(which brew)
ssh [email protected] -p 2222 echo $(hostname)
ssh [email protected] -p 2222 echo '$(hostname)'
$(hostname)
更新:私はこれについて少し間違っていました。
sshを介してコマンドを実行すると、sshはシェルが必要かどうかを決定します(変数の計算など)。必要でない場合は、バイナリをすぐに実行してください。それ以外の場合は、環境変数などを設定できるbashを実行してください。
そのため(あなたの意見では)Brew --versionは失敗します。パスについて言及していません。echo...; brew --version
セミコロンは;
特殊なシェル文字です。 sshはbashを実行してそれを処理します。