Ssh-agent
Материал из noname.com.ua
ssh-agent
Крупный текст
Суть проблемы
- Встроеный агент хоть и есть но не очень удобен так как сокет создает каждый раз новый
- Можно использовать более новый агент из
brew
Устновка своего агента
brew install ssh- Создать файл
~/Library/LaunchAgents/org.homebrew.ssh-agent.plist(кстати в этом месте лежит то что называется login items, точнее часть из них)
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE plist PUBLIC "-//Apple Computer//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd">
<plist version="1.0">
<dict>
<key>Label</key>
<string>org.homebrew.ssh-agent</string>
<key>ProgramArguments</key>
<array>
<string>/usr/local/bin/ssh-agent</string>
<string>-D</string>
<string>-a</string>
<string>/Users/mmazur/.ssh-agent.sock</string>
</array>
<key>Sockets</key>
<dict>
<key>Listeners</key>
<dict>
<key>SockPathName</key>
<string>/Users/jknight/.ssh-agent.sock</string>
<key>SockPathMode</key>
<integer>384</integer> <!-- octal 0600 -->
<key>SockPathGroup</key>
<integer>0</integer>
</dict>
</dict>
<key>EnableTransactions</key>
<true/>
</dict>
</plist>
Обратить внимание на:
/usr/local/bin/ssh-agent- агент установленный изbrew- Ключи
-D-a- нужны для фоновой работы - Путь к сокету
/Users/mmazur/.ssh-agent.sock
Запуск агента
- Загрузить конфигурацию
launchctl load ~/Library/LaunchAgents/org.homebrew.ssh-agent.plist
launchctl list | grep ssh
2086 0 org.openbsd.ssh-agent - 0 org.homebrew.ssh-agent
Далее нужно остановить старого агента и запустить нового
launchctl stop com.openssh.ssh-agent
launchctl start org.homebrew.ssh-agent
launchctl list | grep ssh - 0 org.openbsd.ssh-agent 14693 1 org.homebrew.ssh-agent
Использование агента
Для того что бы подключаться к агенту достаточно указать в .bashrc/.bash_profile
export SSH_AUTH_SOCK=/Users/mmazur/.ssh-agent.sock
(путь /Users/mmazur/.ssh-agent.sock указан в настройках нового агента)