IT技术博客大学习 共学习 共进步

SSH简介

   一、什么是SSH?

   Secure Shell(缩写为SSH),由IETF的网络工作小组(Network Working Group)所制定;SSH为一项创建在应用层和传输层基础上的安全协议,为计算机上的Shell(壳层)提供安全的传输和使用环境。

   最初的SSH协议是由芬兰的一家公司的研究员Tatu Ylönen于1995年设计开发的,但是因为受版权和加密算法等等的限制,现在很多人都转而使用OpenSSH。OpenSSH是SSH的替代软件包,而且是开放源代码和免费的。

   二、基本用法

   SSH主要用于远程登录。假如用户名为java,登录远程主机名为linux,如下命令即可:

     $ ssh java@linux

   SSH的默认端口是22,也就是说,你的登录请求会送进远程主机的22端口。使用p参数,可以修改这个端口。

     $ ssh -p 88 java@linux

   三、安全验证

   SSH之所以能够保证安全,原因在于它采用了公钥加密。

   过程如下:

   (1)远程主机收到用户的登录请求,把自己的公钥发给用户。

   (2)用户使用这个公钥,将登录密码加密后,发送回来。

   (3)远程主机用自己的私钥,解密登录密码,如果密码正确,就同意用户登录。

    四、口令登录

   如果你是第一次登录对方主机,系统会出现下面的提示:

     $ ssh java@linux

     The authenticity of host ‘host (159.211.1.39)’ can’t be established.

     RSA key fingerprint is 98:2e:d7:e0:de:9f:ac:67:28:c2:42:2d:37:16:58:4d.

     Are you sure you want to continue connecting (yes/no)?

   这段话的意思是,无法确认host主机的真实性,只知道它的公钥指纹,问你还想继续连接吗?

   所谓”公钥指纹”,是指公钥长度较长(这里采用RSA算法,长达1024位),很难比对,所以对其进行MD5计算,将它变成一个128位的指纹。上例中是98:2e:d7:e0:de:9f:ac:67:28:c2:42:2d:37:16:58:4d,再进行比较,就容易多了。

   很自然的一个问题就是,用户怎么知道远程主机的公钥指纹应该是多少?回答是没有好办法,远程主机必须在自己的网站上贴出公钥指纹,以便用户自行核对。

   假定经过风险衡量以后,用户决定接受这个远程主机的公钥。

     Are you sure you want to continue connecting (yes/no)? yes

   系统会出现一句提示,表示host主机已经得到认可。

     Warning: Permanently added ‘host,159.211.1.39′ (RSA) to the list of known hosts.

   然后,会要求输入密码。

     Password: (enter password)

   如果密码正确,就可以登录了。

   当远程主机的公钥被接受以后,它就会被保存在文件$HOME/.ssh/known_hosts之中。下次再连接这台主机,系统就会认出它的公钥已经保存在本地了,从而跳过警告部分,直接提示输入密码。

   每个SSH用户都有自己的known_hosts文件,此外系统也有一个这样的文件,通常是/etc/ssh/ssh_known_hosts,保存一些对所有用户都可信赖的远程主机的公钥。

   五、公钥登录

   使用密码登录,每次都必须输入密码,非常麻烦。好在SSH还提供了公钥登录,可以省去输入密码的步骤。

   所谓”公钥登录”,原理很简单,就是用户将自己的公钥储存在远程主机上。登录的时候,远程主机会向用户发送一段随机字符串,用户用自己的私钥加密后,再发回来。远程主机用事先储存的公钥进行解密,如果成功,就证明用户是可信的,直接允许登录shell,不再要求密码。

   这种方法要求用户必须提供自己的公钥。如果没有现成的,可以直接用ssh-keygen生成一个:

     $ ssh-keygen

   运行上面的命令以后,系统会出现一系列提示,可以一路回车。其中有一个问题是,要不要对私钥设置口令(passphrase),如果担心私钥的安全,这里可以设置一个。

   运行结束以后,在$HOME/.ssh/目录下,会新生成两个文件:id_rsa.pub和id_rsa。前者是你的公钥,后者是你的私钥。

   这时再输入下面的命令,将公钥传送到远程主机host上面:

     $ ssh-copy-id java@linux

   好了,从此你再登录,就不需要输入密码了。

   如果还是不行,就打开远程主机的/etc/ssh/sshd_config这个文件,检查下面几行前面”#”注释是否取掉。

     RSAAuthentication yes

     PubkeyAuthentication yes

     AuthorizedKeysFile .ssh/authorized_keys

   然后,重启远程主机的ssh服务。

     // ubuntu系统

     service ssh restart

     // debian系统

     /etc/init.d/ssh restart

   六、authorized_keys文件

   远程主机将用户的公钥,保存在登录后的用户主目录的$HOME/.ssh/authorized_keys文件中。公钥就是一段字符串,只要把它追加在authorized_keys文件的末尾就行了。

   这里不使用上面的ssh-copy-id命令,改用下面的命令,解释公钥的保存过程:

     $ ssh java@linux ‘mkdir -p .ssh && cat >> .ssh/authorized_keys’ < ~/.ssh/id_rsa.pub

   这条命令由多个语句组成,依次分解开来看:(1)”$ ssh user@host”,表示登录远程主机;(2)单引号中的mkdir .ssh && cat >> .ssh/authorized_keys,表示登录后在远程shell上执行的命令:(3)”$ mkdir -p .ssh”的作用是,如果用户主目录中的.ssh目录不存在,就创建一个;(4)’cat >> .ssh/authorized_keys’ < ~/.ssh/id_rsa.pub的作用是,将本地的公钥文件~/.ssh/id_rsa.pub,重定向追加到远程文件authorized_keys的末尾。

   写入authorized_keys文件后,公钥登录的设置就完成了。

建议继续学习

  1. Linux shell脚本使用while循环执行ssh的注意事项 (阅读 8,063)
  2. 在ssh服务里使用chroot (阅读 5,841)
  3. 为什么要用公钥/私钥而不是密码去做SSH身份验证 (阅读 5,701)
  4. 如何让ssh登录更加安全 (阅读 5,604)
  5. ssh连接超时解决办法 (阅读 5,504)
  6. 懒人连ssh不输密码若干大法 (阅读 5,483)
  7. SSH无密码登录 (阅读 5,483)
  8. ssh命令 (阅读 5,225)
  9. 共享会话的ssh连接配置 (阅读 4,705)
  10. 一句话crontab实现防ssh暴力破解 (阅读 4,564)