ssh-agent使用笔记(idea terminal无法 git pull)
2017-02-27 17:39
543 查看
ssh-agent是管理多个ssh key的代理,受管理的私钥通过ssh-add来添加
好处1:不用重复输入密码。
用 ssh-add 添加私钥时,如果私钥有密码的话,照例会被要求输入一次密码,在这之后ssh-agent可直接使用该私钥,无需再次密码认证。
好处2:不用到处部署私钥
假设私钥分别可以登录同一内网的主机 A 和主机 B,出于一些原因,不能直接登录 B。可以通过在 A 上部署私钥或者设置 Forwarding 登录 B,也可以转发认证代理连接在 A 上面使用ssh-agent私钥登录 B;可以在A上直接sftp传文件到B上。
如这边有一台机器是local,能通过公钥直接登陆server1和server2。server1和server2之间无公钥登陆。
现在要在server1上直接登陆server2,在local上执行
接下来登陆server1,注意-A
可以发现server1上多了/tmp/ssh-xxxxxxxxx/agent.xxxxx的socket,之后神奇的事发生了,在server1上可直接进server2,只需执行如下命令,如果加了-A则可以继续ssh forwarding,以至无限的机器forwarding。
同样的原理可以试一下sftp, scp等基于ssh的命令。
如运行ssh-add,遇到“Could not open a connection to your authentication agent.”。
解决:需要ssh-agent启动bash,或者说把bash挂到ssh-agent下面。
参考:
http://www.cnblogs.com/cheche/archive/2011/01/07/1918825.html http://blog.pkufranky.com/2012/08/ssh-agent-forwarding-guide/ http://blog.jobbole.com/33790/
好处1:不用重复输入密码。
用 ssh-add 添加私钥时,如果私钥有密码的话,照例会被要求输入一次密码,在这之后ssh-agent可直接使用该私钥,无需再次密码认证。
好处2:不用到处部署私钥
假设私钥分别可以登录同一内网的主机 A 和主机 B,出于一些原因,不能直接登录 B。可以通过在 A 上部署私钥或者设置 Forwarding 登录 B,也可以转发认证代理连接在 A 上面使用ssh-agent私钥登录 B;可以在A上直接sftp传文件到B上。
如这边有一台机器是local,能通过公钥直接登陆server1和server2。server1和server2之间无公钥登陆。
现在要在server1上直接登陆server2,在local上执行
ssh-agent ssh-add
接下来登陆server1,注意-A
ssh -A server1
可以发现server1上多了/tmp/ssh-xxxxxxxxx/agent.xxxxx的socket,之后神奇的事发生了,在server1上可直接进server2,只需执行如下命令,如果加了-A则可以继续ssh forwarding,以至无限的机器forwarding。
ssh (-A) server2
同样的原理可以试一下sftp, scp等基于ssh的命令。
如运行ssh-add,遇到“Could not open a connection to your authentication agent.”。
解决:需要ssh-agent启动bash,或者说把bash挂到ssh-agent下面。
ssh-agent bash --login -i ssh-add
参考:
http://www.cnblogs.com/cheche/archive/2011/01/07/1918825.html http://blog.pkufranky.com/2012/08/ssh-agent-forwarding-guide/ http://blog.jobbole.com/33790/
相关文章推荐
- Git使用错误收集:-ssh agent失败 错误代码-1
- idea中terminal无法识别git命令行命令解决办法
- Visual Studio 2015 Git无法使用SSH协议的解决方法
- idea中Terminal终端无法执行GIT命令: touch README.md问题解决
- idea中Terminal终端无法执行GIT命令: touch README.md问题解决
- 关于一点coding.net与git配合在AndroidStudio/Idea上的使用笔记个的
- idea中Terminal终端无法执行GIT命令: touch README.md问题解决
- idea使用ssh密钥,git,tortoisegit添加ssh密钥
- Idea中Terminal终端无法执行Git命令
- 添加码云上的SSH公钥以及解决使用命令git pull/push 输入密码问题
- git 无法使用ssh协议连接
- git 使用中的坑,无法pull 版本
- Android Studio使用git无法pull或commit的解决方法
- ssh-agent使用笔记
- Git安装使用笔记 [转]
- [笔记].关于在Quartus II 11.0无法正常使用SignalTap的解决方法
- 解决SUSE Linux下SSH无法使用密码登录问题
- ubuntu下git安装与使用笔记
- GitTortoise + Git Source Control Provider使用笔记
- Git使用笔记(二)-可视化Merge工具Meld