OpenSSHでmsysgitをインストールしています。 gitosisリポジトリに接続しています。 git bashから、.profile
git bashが開かれるたびにssh-agentを実行するファイル(まだ実行されていない場合) このスクリプトを使用
SSH_ENV=$HOME/.ssh/environment
function start_agent {
echo "Initialising new SSH agent..."
/usr/bin/ssh-agent | sed 's/^echo/#echo/' > ${SSH_ENV}
echo succeeded
chmod 600 ${SSH_ENV}
. ${SSH_ENV} > /dev/null
/usr/bin/ssh-add;
}
# Source SSH settings, if applicable
if [ -f "${SSH_ENV}" ]; then
. ${SSH_ENV} > /dev/null
#ps ${SSH_AGENT_PID} doesn't work under cywgin
ps -ef | grep ${SSH_AGENT_PID} | grep ssh-agent$ > /dev/null || {
start_agent;
}
else
start_agent;
fi
また、git bashではなく、Windowsコマンドプロンプトからgitコマンドを実行するgit拡張を使用しています。そのため、sshは実行中のssh-agentを認識しません。これを修正することは可能ですか?
私はあなたと同じ問題を抱えていたので、このコードを追加しようとしました
#! /bin/bash
eval `ssh-agent -s`
ssh-add ~/.ssh/*_rsa
ファイルに.bashrc
私のホームディレクトリ。そしてそれは動作します!
Msysgitの場合、 https://help.github.com/articles/working-with-ssh-key-passphrases によって提供されるソリューションを少し変更する必要があるかもしれません
declare -x SSH_ENV="$HOME/.ssh/environment"
# start the ssh-agent
function start_agent {
echo "Initializing new SSH agent..."
# spawn ssh-agent
ssh-agent | sed 's/^echo/#echo/' > "$SSH_ENV"
echo succeeded
chmod 600 "$SSH_ENV"
. "$SSH_ENV" > /dev/null
ssh-add
}
# test for identities
function test_identities {
# test whether standard identities have been added to the agent already
ssh-add -l | grep "The agent has no identities" > /dev/null
if [ $? -eq 0 ]; then
ssh-add
# $SSH_AUTH_SOCK broken so we start a new proper agent
if [ $? -eq 2 ];then
start_agent
fi
fi
}
# check for running ssh-agent with proper $SSH_AGENT_PID
if [ -n "$SSH_AGENT_PID" ]; then
ps -f -u $USERNAME | grep "$SSH_AGENT_PID" | grep ssh-agent > /dev/null
if [ $? -eq 0 ]; then
test_identities
fi
else
if [ -f "$SSH_ENV" ]; then
. "$SSH_ENV" > /dev/null
fi
ps -f -u $USERNAME | grep "$SSH_AGENT_PID" | grep ssh-agent > /dev/null
if [ $? -eq 0 ]; then
test_identities
else
start_agent
fi
fi
お気づきかもしれませんが、msysgitは-Uを使用せず、-u
おそらく解決したとはいえ... eval
コマンドを使用してssh_agent
プロセススティック:
eval `ssh-agent.exe`
次に、ssh-addを使用して必要なキーを追加します。
Windows 10では、これは私のために働いた
touch ~/.profile
start ~/.profile
を開いて.profile
.profile
に追加します#! /bin/bash
eval `ssh-agent -s`
ssh-add ~/.ssh/*_rsa
これは this answer に基づいています。唯一の違いは、.bashrc
が機能せず、代わりに.profile
が機能したことです。
これを実現する最もスムーズな方法は、SSHエージェントおよびplinkとしてPageantを使用することでした。
リモートで使用されるホスト名に設定されたPuTTYセッションが必要です。
また、PuTTYと同じサイトからダウンロードできるplink.exeも必要です。
そして、キーをロードしてPageantを実行する必要があります。ログイン時にSSHキーを読み込むスタートアップフォルダーにページェントへのショートカットがあります。
Git-scmをインストールすると、OpenSSHではなくtortoise/plinkを使用するように指定できます。
最終的な効果は、パスフレーズを要求されることなく、好きなときにgit-bashを開いてプッシュ/プルできることです。
ページェントにキーがロードされている場合、PuTTYおよびWinSCPセッションにも同じことが当てはまります。それは人生をずっと簡単にします(そして安全にします)。
.profile
をソースとするスクリプトでgit実行可能ファイルをラップすると、ssh-agent
環境変数が読み込まれます。
git
というスクリプトをパスの実際のgitよりも前のディレクトリに配置するか、実際のgitの代わりにラッパーを呼び出すようにgit拡張を構成します。
this answer からの単純な2文字列の解法
# ~/.profile
if ! pgrep -q -U `whoami` -x 'ssh-agent'; then ssh-agent -s > ~/.ssh-agent.sh; fi
. ~/.ssh-agent.sh