Ответ 1
У меня была такая же проблема, как у вас, тогда я попробовал добавить этот код
#! /bin/bash
eval `ssh-agent -s`
ssh-add ~/.ssh/*_rsa
в файл .bashrc
в моем домашнем каталоге. И это работает!
У меня установлен 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-агента. Можно ли это исправить?
У меня была такая же проблема, как у вас, тогда я попробовал добавить этот код
#! /bin/bash
eval `ssh-agent -s`
ssh-add ~/.ssh/*_rsa
в файл .bashrc
в моем домашнем каталоге. И это работает!
Для 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
Даже если вы, вероятно, решили это... используйте команду eval
, чтобы сделать процесс ssh_agent
:
eval `ssh-agent.exe`
Затем используйте ssh-add для добавления необходимых вам ключей.
В Windows 10 это сработало для меня
touch ~/.profile
start ~/.profile
, чтобы открыть .profile
.profile
#! /bin/bash
eval `ssh-agent -s`
ssh-add ~/.ssh/*_rsa
Это основан на этом ответе. Единственное отличие состоит в том, что .bashrc
не работал, вместо этого .profile
работал.
Вы можете обернуть ваш исполняемый файл git с помощью script, который отправит ваш .profile
, в результате чего будут загружены переменные среды ssh-agent
.
Либо поместите script, называемый git
в каталог ранее на вашем пути, чем реальный git, или настройте расширения git, чтобы вызвать вашу обертку вместо реального git.
Я нашел самый гладкий способ достичь этого - использовать Pageant как агент SSH и plink.
Вам нужно настроить сеанс шпатлевки для имени хоста, которое используется на вашем пульте дистанционного управления.
Вам также понадобится plink.exe, который можно загрузить с того же сайта, что и putty.
И вам нужно, чтобы страница выполнялась с загруженным ключом. У меня есть ярлык для показа в моей загрузочной папке, загружающей мой SSH-ключ при входе в систему.
Когда вы устанавливаете git -scm, вы можете указать его для использования черепахи /plink, а не OpenSSH.
Чистый эффект заключается в том, что вы можете открыть git - bash, когда захотите, и нажать/вытащить, не подвергая сомнению кодовые фразы.
То же самое относится к сеансам шпатлевки и WinSCP, когда во время загрузки вашего сайта загружен ваш ключ. Это делает жизнь намного проще (и безопасна).
Простое двухстрочное решение из этого ответа:
# ~/.profile
if ! pgrep -q -U `whoami` -x 'ssh-agent'; then ssh-agent -s > ~/.ssh-agent.sh; fi
. ~/.ssh-agent.sh