38

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

4

7 回答 7

45

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

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

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

于 2013-11-05T15:17:53.923 回答
27

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

于 2013-04-08T02:33:59.803 回答
23

即使您可能已经解决了它......使用eval命令使ssh_agent过程保持不变:

eval `ssh-agent.exe`

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

于 2011-11-10T12:54:07.807 回答
11

在 Windows 10 上,这对我有用

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

这是基于这个答案。唯一的区别是.bashrc没有工作,而是.profile工作。

于 2016-05-04T11:54:57.480 回答
2

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

您需要为远程中使用的主机名配置一个腻子会话。

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

而且您需要在加载密钥的情况下运行 Pageant。我的启动文件夹中有一个选美的快捷方式,当我登录时它会加载我的 SSH 密钥。

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

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

Same applies with putty and WinSCP sessions when pageant has your key loaded. 它使生活变得更加轻松(和安全)。

于 2015-03-04T00:51:30.047 回答
1

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

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

于 2011-06-03T12:17:31.447 回答
0

此答案中的简单两个字符串解决方案

# ~/.profile
if ! pgrep -q -U `whoami` -x 'ssh-agent'; then ssh-agent -s > ~/.ssh-agent.sh; fi
. ~/.ssh-agent.sh
于 2017-10-13T20:07:44.217 回答