SSH实现双向认证

由于经常需要使用scp在两台机器间拷贝文件,每次都输入密码太麻烦,于是按下面的步骤配置了一下,再使用ssh或scp登录远程机器时就不需输入密码了:

A主机:192.168.100.82
B主机:192.168.100.83

Linux/Unix双机建立信任

1.在A机生成证书

在A机root用户或其他用户下执行ssh-keygen命令,在需要输入的地方,直接回车,生成建立安全信任关系的证书。

[root@localhost ~]#ssh-keygen -t rsa

注意:在程序提示输入passphrase时直接输入回车,表示无证书密码。
上述命令将生成私钥证书id_rsa和公钥证书id_rsa.pub,存放在用户家目录的.ssh子目录中.

2.查看~/.ssh生成密钥的文件

[root@localhost ~]# ll /root/.ssh/
total 8
-rw------- 1 root root 1675 Apr 27 15:55 id_rsa
-rw-r--r-- 1 root root 400 Apr 27 15:55 id_rsa.pub

3.A对B建立信任关系

将A主机的公钥证书id_rsa.pub复制到机器B主机的root家目录的.ssh子目录中,同时将文件名更换为authorized_keys,此时需要输入B主机的root用户密码(还未建立信任关系)。建立了客户端到服务器端的信任关系后,客户端就可以不用再输入密码,就可以从服务器端拷贝数据了。

scp -r -P 22 /root/.ssh/id_rsa.pub root@192.168.100.83:/root/.ssh/authorized_keys

如果做单向认证,这里已经可以实现A到B的免秘钥上传下载了.

4.B对A建立信任关系

在B机上执行同样的操作,建立B对A的信任关系。

[root@localhost ~]#ssh-keygen -t rsa
root@localhost ~]# ll /root/.ssh/
total 8
-rw-r--r-- 1 root root 1678 Apr 27 15:59 authorized_keys
-rw------- 1 root root 1675 Apr 27 15:55 id_rsa
-rw-r--r-- 1 root root 400 Apr 27 15:55 id_rsa.pub

将B主机的公钥证书id_rsa.pub复制到机器A主机的root家目录的.ssh子目录中,同时将文件名更换为authorized_keys

scp -r -P 22 /root/.ssh/id_rsa.pub root@192.168.100.82:/root/.ssh/authorized_keys

这样A和B主机就可以互相传文件而不需要密码了.

如果连接反应慢,请修改以下两参数

/etc/ssh/sshd_config
GSSAPIAuthentication no
UseDNS no

重启sshd

service sshd restart

################################################################################

二.使用ssh-keygen和ssh-copy-id三步实现SSH无密码登录

由于上面这样复制文件很麻烦,以下给出更为方便的方法,在做单向ssh认证时都在本端计算机进行, 即使用ssh-copy-id进行操作,它可以直接在对端生成authorized_keys文件.

    a、运行:ssh-keygen -t rsa 
    b、然后拍几下回车(均选择默认)
    c、运行: ssh-copy-id -i .ssh/id_rsa.pub "-p 6168 user1@192.168.3.192"
    d、输入被控端的密码,就可以了,这样就在对端的.ssh目录下自动生成authorized_keys,就算对端没有.ssh目录也会自动创建,这里的-p指定的是我的ssh的端口号。
实例操作:
[user1@localhost ~]$ ssh-keygen -t rsa
Generating public/private rsa key pair.
Enter file in which to save the key (/home/user1/.ssh/id_rsa):
Created directory '/home/user1/.ssh'.
Enter passphrase (empty for no passphrase):
Enter same passphrase again:
Your identification has been saved in /home/user1/.ssh/id_rsa.
Your public key has been saved in /home/user1/.ssh/id_rsa.pub.
The key fingerprint is:
da:e3:f0:2b:93:47:15:4d:a1:dc:68:00:07:ec:41:87 user1@localhost
The key's randomart image is:
+--[ RSA 2048]----+
| o+++ oo. |
| Eo o.+. |
| . . =.. |
| . .. |
| S. |
| o. |
| ooo |
| ++.. |
| ++. |
+-----------------+ [user1@localhost ~]$ ssh-copy-id -i .ssh/id_rsa.pub "-p 6168 user1@192.168.3.192"
The authenticity of host '[192.168.3.192]:6168 ([192.168.3.192]:6168)' can't be established.
RSA key fingerprint is 8d:8c:22:67:68:f7:ad:1e:83:f3:4c:d4:32:d8:53:d6.
Are you sure you want to continue connecting (yes/no)? yes
Warning: Permanently added '[192.168.3.192]:6168' (RSA) to the list of known hosts.
user1@192.168.3.192's password:
Now try logging into the machine, with "ssh '-p 6168 user1@192.168.3.192'", and check in: .ssh/authorized_keys to make sure we haven't added extra keys that you weren't expecting. [user1@localhost ~]$
#这样就会自动在192.168.3.192远端机器的.ssh目录下创建authorized_keys文件.  
如果需要sudo权限,需要将本机的root的公钥放到对端账号的.ssh/authorized_keys里面.
通过shell脚本,自动生成key密钥,实现批量自动化生成和分发
#!/bin/bash
if [ ! -f ~/.ssh/id_rsa ];then
ssh-keygen -t rsa -P "" -f ~/.ssh/id_rsa
else
echo "id_rsa has created ..."
fi

其中:

 -t type
             指定要创建的密钥类型。可以使用:"rsa1"(SSH-1) "rsa"(SSH-2) "dsa"(SSH-2).
 -P passphrase
             提供(旧)密语.
-f filename
             指定密钥文件名.
 
 

最新文章

  1. Android 数字签名
  2. Synchronization Service Manager
  3. Java中引用类 strong reference .SoftReference 、 WeakReference 和 PhantomReference的区别
  4. js闭包初体验
  5. php课程---JavaScript与Jquery的区别(转)
  6. Material Design入门(三)
  7. Unity-Animator深入系列---目标匹配Target Matching
  8. HDU-4455 Substrings(DP)
  9. 深入理解javascript的闭包
  10. [物理学与PDEs]第4章习题参考解答
  11. MAC OS下免费下载YouTube
  12. mysql之索引
  13. ZZTHX-Androidannotations框架联想
  14. uCGUI窗口重绘代码分析
  15. 页面全屏显示JS代码
  16. es6面试问题——Promise
  17. 对Numpy广播操作的理解
  18. Can’t open /dev/* exclusively. Mounted filesystem?解决
  19. 谈谈App的混合开发
  20. Heroku创始人Adam Wiggins发布十二要素应用宣言

热门文章

  1. 【转】Android项目使用Ant打包,生成build.xml
  2. vue2.0的contextmenu右键菜单
  3. Java获取此次请求URL以及服务器根路径的方法
  4. 豆瓣源安装requirements.txt
  5. Zabbix监控JVM内存
  6. Android开发(七)——判断网络状态
  7. Html模板渲染引擎Hogan
  8. backbone的对象继承实现
  9. openCV—Python(5)—— 图像几何变换
  10. 自适应瀑布型布局(手机,PC全兼容)