首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

SSH 登录流程分析

本文首发于 https://jaychen.cc作者:jaychen(https://segmentfault.com/u/chenjiayao)

写一篇短文,介绍 ssh 密钥登录远程服务器流程和注意事项。

登录流程

密钥登录比密码登录安全,主要是因为他使用了非对称加密,登录过程中需要用到密钥对。整个登录流程如下:

远程服务器持有公钥,当有用户进行登录,服务器就会随机生成一串字符串,然后发送给正在进行登录的用户。

用户收到远程服务器发来的字符串,使用与远程服务器公钥配对的私钥对字符串进行加密,再发送给远程服务器。

服务器使用公钥对用户发来的加密字符串进行解密,得到的解密字符串如果与第一步中发送给客户端的随机字符串一样,那么判断为登录成功。

整个登录的流程就是这么简单,但是在实际使用 ssh 登录中还会碰到一些小细节,这里演示一遍 ssh 远程登录来展示下这些细节问题。

生成密钥对

使用 就可以直接生成登录需要的密钥对。 是 Linux 下的命令,不添加任何参数就可以生成密钥对。

执行 会出现如上的提示,在 处这里提示用户输入生成的私钥的名称,如果不填,默认私钥保存在 文件中。这里要注意两点:

生成的密钥,会放在执行 命令的用户的家目录下的 文件夹中。即 目录下。

生成的公钥的文件名,通常是私钥的文件名后面加 的后缀。

处,提示输入密码,注意这里的密码是用来保证私钥的安全的。如果填写了密码,那么在使用密钥进行登录的时候,会让你输入密码,这样子保证了如果私钥丢失了不至于被恶意使用。话是这么说,但是平时使用这里我都是直接略过。

是重复 输入的密码,这里就不废话了。

生成密钥之后,就可以在 下看到两个文件了(我这里会放在 下是因为我使用 jaychen 用户来执行 命令)

生成的私钥还要注意一点:私钥的权限应该为 ,如果私钥的权限过大,那么私钥任何人都可以读写就会变得不安全。ssh 登录就会失败。

首次 ssh 登录

登录远程服务器的命令是

这里开始要注意两个用户的概念:

本地执行这条命令的用户,即当前登录用户,我这里演示的用户名称是 jaychen。

要登录到远程服务器的用户。

在开始登录之前,我们要首先要把生成公钥上传到服务器。

公钥的内容要保存到要登录的用户的家目录下的文件中。假设你之后要使用 root 用户登录远程服务器,那么公钥的内容应该是保存在 中。注意 文件是可以保存多个公钥信息的,每个公钥以换行分开。

上传完毕之后,执行

这个时候,如上面说的,远程服务器会发送一段随机字符串回来,这个时候需要使用私钥对字符串进行加密。而这个私钥会去执行该命令的用户的家目录下的 目录读取私钥文件,默认私钥文件为 文件。即 文件。假设在生成密钥的时候对私钥进行了加密,那么这个时候就需要输入密码。

上面的流程用户登录的时候是不会感知的,ssh 在背后完成了所有的校验操作,如果密钥匹配的话,那么用户就可以直接登录到远程服务器,但是如果是首次登录的话,会出现类似下面的提示:

这句话的意思是,远程服务器的真实身份无法校验,只知道公钥指纹(公钥的 MD5 值)为 ,是否真的要建立连接。出现上面的提示是因为避免存在中间人攻击

中间人攻击

中间人攻击的前提是,你第一次登录一台远程服务器,你除了用户名、用户名对应的公钥私钥以及服务器 ip 之外,对远程服务器丝毫不了解的情况下。假设你 ssh 远程登录 192.168.1.1 的远程主机,在连接过程中被第三者拦截,第三者假冒自己为 192.168.1.1 的主机,那么你就会直接连接到其他人的服务器上。这就是中间人攻击。

为了避免中间人攻击,ssh 在首次登录的时候会返回公钥指纹,用户需要自己手动去比对你要登录的远程服务器的公钥的公钥指纹和 ssh 返回的公钥指纹是否一样

经过比较公钥指纹,确认该服务器就是你要登录的服务器,输入 之后就可以成功登录。整个登录流程结束。

known_hosts 文件

第一次登录之后,在本机的 目录下就会生成一个 的文件,内容类似下面

这个文件记录了远程主机 ip 和远程主机对应的公钥指纹,那么在下次登录的时候,远程主机发送过来的公钥指纹,直接和 文件中对应 ip 的公钥指纹比较即可。

config 配置

很多时候,我们开发可能需要连接多台远程服务器,并且需要配置 git 服务器的私钥。那么这么多的服务器不能共用一套私钥,不同的服务器应该使用不同的私钥。但是我们从上面的连接流程可以看到,ssh 默认是去读取 文件作为私钥登录的。如果想要不同的服务器使用不同的私钥进行登录,那么需要在 目录下编写 文件来进行配置。

的配置很简单,只要指明哪个用户登录哪台远程服务器需要使用哪个私钥即可。下面给出一个配置示例。

上面 文件字段含义如下:

Host 指明了远程主机的 ip,除了使用 ip 地址,也可以直接使用网址。

User 指的是登录远程主机的用户。

IdentityFile 指明使用哪个私钥文件。

编写好 文件之后,需要把 文件的权限改为 。如果权限过大,ssh 会禁止登录。

觉得本文对你有帮助?请分享给更多人

关注「程序员宝库」,一起学习编程技术!

  • 发表于:
  • 原文链接http://kuaibao.qq.com/s/20171213A0QW6900?refer=cp_1026
  • 腾讯「腾讯云开发者社区」是腾讯内容开放平台帐号(企鹅号)传播渠道之一,根据《腾讯内容开放平台服务协议》转载发布内容。
  • 如有侵权,请联系 cloudcommunity@tencent.com 删除。

扫码

添加站长 进交流群

领取专属 10元无门槛券

私享最新 技术干货

扫码加入开发者社群
领券