SSH
什么是SSH
SSH是一种网络协议,用于计算机之间的加密通信。
公钥Public Key与私钥Private Key
SSH需要生成公钥Public Key和私钥Private Key, 常用的是使用RSA算法生成id_rsa.pub
和id_rsa
。 公钥Public Key(id_rsa.pub
)是可以暴露在网络传输上的,是不安全的。而私钥Private Key(id_rsa
)是不可暴露的,只能存在客户端本机上。 所以公钥Public Key(id_rsa.pub
)的权限是644,而私钥Private Key(id_rsa
)的权限只能是600。如果权限不对,SSH会认为公钥Public Key(id_rsa.pub
)和私钥Private Key(id_rsa
)是不可靠的,就无法正常使用SSH登陆了。
同时在服务端会有一个~/.ssh/authorized_keys
文件,里面存放了多个客户端的公钥Public Key(id_rsa.pub
),就表示拥有这些Public Key的客户端就可以通过SSH登陆服务端。
SSH公钥登陆过程
- 客户端发出公钥登陆的请求(
ssh user@host
) - 服务端返回一段随机字符串
- 客户端用私钥Private Key(
id_rsa
)加密这个字符串,再发送回服务端 - 服务端用
~/.ssh/authorized_keys
里面存储的公钥Public Key去解密收到的字符串。如果成功,就表明这个客户端是可信的,客户端就可以成功登陆
由此可见,只要多台电脑上的的公钥Public Key(id_rsa.pub
)和私钥Private Key(id_rsa
)是一样的,对于服务端来说着其实就是同一个客户端。所以可以通过复制公钥Public Key(id_rsa.pub
)和私钥Private Key(id_rsa
)到多台电脑来实现共享登陆。