Получение ssh-агента для работы с git запустите из командной оболочки Windows

У меня установлен msysgit с OpenSSH. Я подключаюсь к репозиторию гитозиса. Из git bash я создал файл .profile, который запускает ssh-agent (если он еще не запущен) при каждом открытии git bash, используя этот 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, которые запускают команду git из командной строки Windows, а не git bash. Таким образом, ssh не видит запущенного ssh-агента. Можно ли это исправить?

Ответ 1

У меня была такая же проблема, как у вас, тогда я попробовал добавить этот код

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

в файл .bashrc в моем домашнем каталоге. И это работает!

Ответ 2

Для 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

Ответ 3

Даже если вы, вероятно, решили это... используйте команду eval, чтобы сделать процесс ssh_agent:

eval `ssh-agent.exe`

Затем используйте ssh-add для добавления необходимых вам ключей.

Ответ 4

В Windows 10 это сработало для меня

  • run git bash
  • touch ~/.profile
  • start ~/.profile, чтобы открыть .profile
  • добавьте следующее в .profile
#! /bin/bash 
eval `ssh-agent -s` 
ssh-add ~/.ssh/*_rsa

Это основан на этом ответе. Единственное отличие состоит в том, что .bashrc не работал, вместо этого .profile работал.

Ответ 5

Вы можете обернуть ваш исполняемый файл git с помощью script, который отправит ваш .profile, в результате чего будут загружены переменные среды ssh-agent.

Либо поместите script, называемый git в каталог ранее на вашем пути, чем реальный git, или настройте расширения git, чтобы вызвать вашу обертку вместо реального git.

Ответ 6

Я нашел самый гладкий способ достичь этого - использовать Pageant как агент SSH и plink.

Вам нужно настроить сеанс шпатлевки для имени хоста, которое используется на вашем пульте дистанционного управления.

Вам также понадобится plink.exe, который можно загрузить с того же сайта, что и putty.

И вам нужно, чтобы страница выполнялась с загруженным ключом. У меня есть ярлык для показа в моей загрузочной папке, загружающей мой SSH-ключ при входе в систему.

Когда вы устанавливаете git -scm, вы можете указать его для использования черепахи /plink, а не OpenSSH.

Чистый эффект заключается в том, что вы можете открыть git - bash, когда захотите, и нажать/вытащить, не подвергая сомнению кодовые фразы.

То же самое относится к сеансам шпатлевки и WinSCP, когда во время загрузки вашего сайта загружен ваш ключ. Это делает жизнь намного проще (и безопасна).

Ответ 7

Простое двухстрочное решение из этого ответа:

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