【问题标题】:Getting ssh-agent to work with git run from windows command shell让 ssh-agent 与 Windows 命令 shell 中的 git run 一起工作
【发布时间】:2011-04-09 19:11:53
【问题描述】:

我用 OpenSSH 安装了 msysgit。我正在连接到一个 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。有可能解决这个问题吗?

【问题讨论】:

标签: git git-bash ssh-agent


【解决方案1】:

简单的两个字符串解决方案来自this answer

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

【讨论】:

    【解决方案2】:

    在 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 起作用。

    【讨论】:

      【解决方案3】:

      我遇到了和你一样的问题,然后我尝试添加此代码

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

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

      【讨论】:

      • 这对我有用。我认为我的特殊问题是我需要指定我需要使用的 _rsa 文件。
      • 谢谢@bricklore :)
      • 反复退出和打开新的 bash 会话会导致每个新会话都生成一个新的 ssh-agent.exe。 @Braiam 的答案中链接到的文章中的解决方案对我来说阻止了这种情况。
      【解决方案4】:

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

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

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

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

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

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

      当 pageant 加载了您的密钥时,putty 和 WinSCP 会话也是如此。它让生活变得更加轻松(和安全)。

      【讨论】:

        【解决方案5】:

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

        eval `ssh-agent.exe`
        

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

        【讨论】:

        • 每次打开 git bash 时都会产生一个新的 ssh-agent 顶级进程。
        • 啊,你看,至少在我检查它时不是真的,如果我没记错的话,它会检查是否已经有一个正在运行,否则它确实会产生进程。现在他们修复了它,所以没有理由再使用它了
        • @Cu7l4ss 如果他们修好了,那我为什么会遇到这个问题??? - 我可以启动 ssh-agent 并添加密钥……但它立即消失了,'ssh-add -l' 返回“代理没有身份”。我什至走到这一步的唯一方法是通过您列出的命令。 -- 仅供参考,仍然是当前问题。
        • 反复退出和打开新的 bash 会话会导致每个新会话都生成一个新的 ssh-agent.exe。 @Braiam 的答案中链接到的文章中的解决方案对我来说阻止了这种情况。
        【解决方案6】:

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

        【讨论】:

        • 请注意,the article on GitHub 提供了此脚本的更简单(可能更可靠)的版本。
        • 他们似乎更新了他们的代码。我想知道您的定制版本还需要吗?我建议先尝试文章中的解决方案。
        【解决方案7】:

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

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

        【讨论】:

          猜你喜欢
          • 2014-10-17
          • 1970-01-01
          • 1970-01-01
          • 2021-02-24
          • 1970-01-01
          • 2021-12-03
          • 2021-02-25
          • 2013-02-03
          • 2014-02-28
          相关资源
          最近更新 更多