让ssh-agent与windows命令shell中的git一起运行

时间:2010-09-08 14:53:03

标签: git git-bash ssh-agent

我安装了msysgit,使用OpenSSH。我正在连接一个gitosis回购。从git bash中,我创建了一个.profile文件,每次打开git bash时运行ssh-agent(如果尚未运行),using this script

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扩展,它从Windows命令提示符运行git命令,而不是git bash。所以,ssh没有看到正在运行的ssh-agent。有可能解决这个问题吗?

7 个答案:

答案 0 :(得分:44)

我和你有同样的问题,然后我尝试添加此代码

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

到我的主目录中的文件.bashrc。它有效!

答案 1 :(得分:26)

对于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

你可能会注意到我做的唯一改变是在ps调用中,因为msysgit不使用-U但是-u

答案 2 :(得分:23)

即使你可能已经解决了它......使用eval命令使ssh_agent进程坚持下去:

eval `ssh-agent.exe`

然后使用ssh-add添加所需的密钥。

答案 3 :(得分:10)

在Windows 10上,这对我有用

  1. 运行git bash
  2. touch ~/.profile
  3. start ~/.profile打开.profile
  4. 将以下内容添加到.profile
  5. #! /bin/bash 
    eval `ssh-agent -s` 
    ssh-add ~/.ssh/*_rsa
    

    这基于this answer。唯一的区别是.bashrc无效,而.profile无效。

答案 4 :(得分:2)

我发现实现这一目标最顺畅的方法是使用Pageant作为SSH代理和plink。

您需要为您的遥控器中使用的主机名配置一个putty会话。

您还需要plink.exe,可以从与putty相同的站点下载。

你需要在加载密钥的情况下运行Pageant。我在我的启动文件夹中有一个快捷方式,可以在我登录时加载我的SSH密钥。

当您安装git-scm时,您可以指定它使用tortoise / plink而不是OpenSSH。

净效果是你可以随时打开git-bash并推/拉而不会受到密码短语的挑战。

当pageant加载了密钥时,putty和WinSCP会话也是如此。它使生活变得更加容易(并且安全)。

答案 5 :(得分:1)

您可以使用源自.profile的脚本包装git可执行文件,从而导致加载ssh-agent个环境变量。

将一个名为git的脚本放在路径中比真实git更早的目录中,或者配置git扩展来调用你的包装器来代替真正的git。

答案 6 :(得分:0)

来自this answer

简单的双字符串解决方案

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