web-dev-qa-db-ja.com

Windowsコマンドシェルからgitを実行してssh-agentを動作させる

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を認識しません。これを修正することは可能ですか?

35
Jacko

私はあなたと同じ問題を抱えていたので、このコードを追加しようとしました

#! /bin/bash 
eval `ssh-agent -s` 
ssh-add ~/.ssh/*_rsa

ファイルに.bashrc私のホームディレクトリ。そしてそれは動作します!

44
Fery Wardiyanto

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

26
Braiam

おそらく解決したとはいえ... evalコマンドを使用してssh_agentプロセススティック:

eval `ssh-agent.exe`

次に、ssh-addを使用して必要なキーを追加します。

23
Cu7l4ss

Windows 10では、これは私のために働いた

  1. git bashを実行します
  2. touch ~/.profile
  3. start ~/.profileを開いて.profile
  4. 以下を.profileに追加します
#! /bin/bash 
eval `ssh-agent -s` 
ssh-add ~/.ssh/*_rsa

これは this answer に基づいています。唯一の違いは、.bashrcが機能せず、代わりに.profileが機能したことです。

10
Thoran

これを実現する最もスムーズな方法は、SSHエージェントおよびplinkとしてPageantを使用することでした。

リモートで使用されるホスト名に設定されたPuTTYセッションが必要です。

また、PuTTYと同じサイトからダウンロードできるplink.exeも必要です。

そして、キーをロードしてPageantを実行する必要があります。ログイン時にSSHキーを読み込むスタートアップフォルダーにページェントへのショートカットがあります。

Git-scmをインストールすると、OpenSSHではなくtortoise/plinkを使用するように指定できます。

最終的な効果は、パスフレーズを要求されることなく、好きなときにgit-bashを開いてプッシュ/プルできることです。

ページェントにキーがロードされている場合、PuTTYおよびWinSCPセッションにも同じことが当てはまります。それは人生をずっと簡単にします(そして安全にします)。

2
Alasdair

.profileをソースとするスクリプトでgit実行可能ファイルをラップすると、ssh-agent環境変数が読み込まれます。

gitというスクリプトをパスの実際のgitよりも前のディレクトリに配置するか、実際のgitの代わりにラッパーを呼び出すようにgit拡張を構成します。

1
Andrew Aylett

this answer からの単純な2文字列の解法

# ~/.profile
if ! pgrep -q -U `whoami` -x 'ssh-agent'; then ssh-agent -s > ~/.ssh-agent.sh; fi
. ~/.ssh-agent.sh
0
oklas