总览 (SYNOPSIS)

ssh-agent [-a bind_address ] [-c | -s ] [-t life ] [-d ] [command [args ... ] ] ssh-agent [-c | -s ] -k

描述 (DESCRIPTION)

用来掌管公开密钥认证系统(RSA, DSA)中的私钥. 这个概念源于让在 X 会话或登录会话之初启动, 使其他窗口或程序成为的客户. 当它们用 ssh(1) 登录其他机器的时候, 可以通过环境变量找到代理程序, 并自动进行认证.

可用的选项有:

-a bind_address
把代理和 UNIX 域 socket bind_address 绑定. 默认地址是 /tmp/ssh-XXXXXXXX/agent.<ppid>
-c
stdout 上输出 C-shell 命令. 如果 SHELL 看上去象一个 csh 类型的 shell, 这个就成为默认项.
-s
stdout 上输出 Bourne shell 命令. 如果 SHELL 看上去不象一个 csh 类型的 shell, 这个就成为默认项.
-k
结束当前代理 (由 SSH_AGENT_PID 环境变量给出).
-t life
设置最大生命周期的默认值, 用于加入的身份数据. 生命周期以秒为单位, 也可以用 sshd(8) 中规定的时间格式. 用 ssh-add1 向代理添加身份数据时, 可以指定另一个生命周期, 而不用这个默认值. 不使用这个选项时, 默认的最大生命周期是永恒.
-d
调试模式. 指定这个选项后, 不进行 fork.

如果给出命令行, 它将按代理的子进程运行. 命令结束时, 代理也结束.

代理最初不掌握任何私钥. 密钥通过 ssh-add1 加入. 不带参数运行 ssh-add1 时, 它添加 $HOME/.ssh/id_rsa $HOME/.ssh/id_dsa 和 $HOME/.ssh/identity 文件的内容. 如果身份数据需要用密语访问, ssh-add1 将询问这个密语 (X11 下用一个小程序, 没有 X 则从终端读取), 然后把身份数据送往代理. 代理能够保存多个身份数据, 并且自动使用这些数据. ssh-add -l 命令显示出目前代理掌管的身份数据.

这个方式的设想是, 在用户的本地 PC, 笔记本计算机, 或终端上运行代理程序. 认证数据无须保存在其他任何机器上, 而认证的密语决不通过网络传递. 但是, 和代理的连接通过 SSH 远程登录被转发, 因而用户能够在网络的任何地方安全行使与其身份一致的权利.

设置代理程序有两个主要方法: 或者让代理启动一个子命令输出某些环境变量; 或者让代理程序输出所需的 shell 命令 ( sh(1) 或 csh(1) 语法都能够产生). 之后 ssh(1) 获取这些变量, 据此和代理建立连接.

代理程序决不会在请求的通道中传送私钥, 需要私钥的操作将由代理完成, 然后把结果返回给请求者. 这样使用代理就不会把私钥暴露给客户端.

程序将创建一个 UNIX 域的 socket, 它只让当前用户访问, SSH_AUTH_SOCK 环境变量保存这个 socket 的名字. 这个方法容易被 root 用户或当前用户的不同实例滥用.

SSH_AGENT_PID 环境变量保存着代理程序的 PID.

当在命令行上给出的命令结束时, 代理程序也就自动退出.

文件 (FILES)

$HOME/.ssh/identity
内含用户的协议第一版的 RAS 身份数据.
$HOME/.ssh/id_dsa
内含用户的协议第二版的 DSA 身份数据.
$HOME/.ssh/id_rsa
内含用户的协议第二版的 RAS 身份数据.
/tmp/ssh-XXXXXXXX/agent.<ppid>
Unix 域 socket, 包含和认证代理的连接. 这些 socket 只允许它们的拥有者读取. 代理程序退出时自动删除这些 socket.  

最新文章

  1. 计算机程序的思维逻辑 (49) - 剖析LinkedHashMap
  2. Spring Data JPA 学习记录1 -- 单向1:N关联的一些问题
  3. Source Insight设置
  4. 数据源DBCP一二
  5. Open Wifi SSID Broadcast vulnerability
  6. asp.net缓存(三)
  7. weblogic一些基本概念
  8. monkey测试样例
  9. docker eureka 注册中心 服务提供者通信机制
  10. 使用vmware提示无法打开内核设备 \\.\Global\vmx86: 系统找不到指定的文件
  11. 项目冲刺 Seventh
  12. 【转】Web前端性能优化——如何提高页面加载速度
  13. nodejs----http系统模块使用和fs系统模块
  14. materializecss的水波纹效果
  15. springboot + mybatis +druid
  16. StringBuilder的实现与技巧ZZ
  17. ES curl bulk 导入数据
  18. 转转转!java继承中的this和super
  19. Windows&ldquo;储存并显示最近在开始菜单和任务栏中打开的项目&rdquo;显示灰色问题解决
  20. 【bug】使用微信分享SDK,配置成功但分享信息异常

热门文章

  1. MATLAB 和 armadillo 数据转换
  2. (arm板子tensorflow安装)armv7板子pip安装的wheel
  3. sts创建maven项目 引入spring,报错
  4. 【2019 Multi-University Training Contest 9】
  5. 31 October
  6. CSS3订单提交按钮Loading代码
  7. womenzijide
  8. PHP-利用二叉堆实现TopK-算法
  9. mysql_DML_select_聚合join
  10. Java Web项目启动执行顺序