Linux使用密钥登录

写这篇文章的起因是我要使用 rsync下载远程服务器的文件备份

但是每次使用 rsync的时候都要输入密码,非常麻烦,而且我是备份脚本,后台运行的时候不能输入密码

解决方法就是我们使用密钥登录

先来看看原理图

 

这种方法比较安全,只要保管好私钥 就很安全了

将公钥(pub)发送到你要免密登录的服务器的 /root/.ssh/ 这个目录下

实现

1. 制作密钥对

#在客户端生成密钥和公钥
ssh-keygen -t rsa
Generating public/private rsa key pair.
Enter file in which to save the key (/root/.ssh/id_rsa): <== 按 Enter
Created directory '/root/.ssh'.
Enter passphrase (empty for no passphrase): <== 输入密钥锁码,或直接按 Enter 留空
Enter same passphrase again: <== 再输入一遍密钥锁码
Your identification has been saved in /root/.ssh/id_rsa. <== 私钥
Your public key has been saved in /root/.ssh/id_rsa.pub. <== 公钥
The key fingerprint is:
0f:d3:e7:1a:1c:bd:5c:03:f1:19:f1:22:df:9b:cc:08 root@host

2.发送到需要免密登录的服务器

scp /root/.ssh/id_rsa.pub root@192.168.3.5:/root/.ssh/

3. 在服务器上安装公钥

[root@host ~]$ cd .ssh
[root@host .ssh]$ cat id_rsa.pub >> authorized_keys

公钥文件覆盖下 authorized_keys 这个文件

如此便完成了公钥的安装。为了确保连接成功,请保证以下文件权限正确:

[root@host .ssh]$ chmod 600 authorized_keys
[root@host .ssh]$ chmod 700 ~/.ssh

4. 设置 SSH,打开密钥登录功能

编辑 /etc/ssh/sshd_config 文件,进行如下设置:

RSAAuthentication yes
PubkeyAuthentication yes

另外,请留意 root 用户能否通过 SSH 登录:

PermitRootLogin yes

配置完成之后重启下 SSH服务

这是centos 6的命令

[root@host .ssh]$ service sshd restart

如果你是CentOS 7.X 使用如下命令重启 ssh

systemctl restart sshd

5.测试结果

rsync -av root@192.168.3.5:/root/*  ./ 
[root@localhost ~]# rsync -av root@47.106.67.99:/root/*  ./ 
receiving incremental file list

sent 20 bytes  received 80 bytes  66.67 bytes/sec
total size is 0  speedup is 0.00

发现没有显示需要输入密码

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

java-superchen

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值