阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

Linux下ssh高级使用–免密登录

29次阅读
没有评论

共计 2405 个字符,预计需要花费 7 分钟才能阅读完成。

导读 在 linux 系统中密码的保存是非常重要的,在企业中的 WEB 集群环境中,进行统一的版本更新和配置文件的同步免密登录是非常重要的。在自动化运维,统一管理都是离不开 Linux 的免密登录。下面我们来看下免密登录。
1.Linux 下生成密钥

ssh-keygen 的命令手册,通过”man ssh-keygen“命令:
Linux 下 ssh 高级使用–免密登录

通过命令”ssh-keygen -t rsa“
Linux 下 ssh 高级使用–免密登录

生成之后会在用户的根目录生成一个“.ssh”的文件夹
Linux 下 ssh 高级使用–免密登录

进入“.ssh”会生成以下几个文件
Linux 下 ssh 高级使用–免密登录

authorized_keys: 存放远程免密登录的公钥, 主要通过这个文件记录多台机器的公钥

id_rsa : 生成的私钥文件

id_rsa.pub:生成的公钥文件

know_hosts : 已知的主机公钥清单

如果希望 ssh 公钥生效需满足至少下面两个条件:

阿里云 2 核 2G 服务器 3M 带宽 61 元 1 年,有高配

腾讯云新客低至 82 元 / 年,老客户 99 元 / 年

代金券:在阿里云专用满减优惠券

2. 远程免密登录

原理图:

Linux 下 ssh 高级使用–免密登录

常用以下几种方法:

2.1 通过 ssh-copy-id 的方式

阿里云 2 核 2G 服务器 3M 带宽 61 元 1 年,有高配

腾讯云新客低至 82 元 / 年,老客户 99 元 / 年

代金券:在阿里云专用满减优惠券

举例:

[root@test .ssh]# ssh-copy-id -i ~/.ssh/id_rsa.pub 192.168.91.135
root@192.168.91.135's   password:
Now try logging into the machine, with "ssh'192.168.91.135'", and check in:
.ssh/authorized_keys  to make sure we haven't added extra keys that you weren't expecting.
[root@test .ssh]# ssh root@192.168.91.135 
Last login: Mon Oct 10 01:25:49 2016 from 192.168.91.133 
[root@localhost ~]#

常见错误:

[root@test ~]# ssh-copy-id -i ~/.ssh/id_rsa.pub 192.168.91.135
-bash: ssh-copy-id: command not found // 提示命令不存在 

解决办法:yum -y install openssh-clients

2.2 通过 scp 将内容写到对方的文件中

阿里云 2 核 2G 服务器 3M 带宽 61 元 1 年,有高配

腾讯云新客低至 82 元 / 年,老客户 99 元 / 年

代金券:在阿里云专用满减优惠券

举例:

[root@test .ssh]# scp -p ~/.ssh/id_rsa.pub root@192.168.91.135:/root/.ssh/authorized_keys
 root@192.168.91.135's password:  
id_rsa.pub 100% 408 0.4KB/s 00:00
  
[root@test .ssh]#   
[root@test .ssh]# ssh root@192.168.91.135
Last login: Mon Oct 10 01:27:02 2016 from 192.168.91.133 
[root@localhost ~]#
2.3 通过 Ansible 实现批量免密

2.3.1 将需要做免密操作的机器 hosts 添加到 /etc/ansible/hosts 下:

[Avoid close]
192.168.91.132
192.168.91.133
192.168.91.134

2.3.2 执行命令进行免密操作

阿里云 2 核 2G 服务器 3M 带宽 61 元 1 年,有高配

腾讯云新客低至 82 元 / 年,老客户 99 元 / 年

代金券:在阿里云专用满减优惠券

示例:

[root@test sshpass-1.05]# ansible test -m authorized_key -a "user=root key='{{lookup('file','/root/.ssh/id_rsa.pub') }}'" -k   
SSH password: -----> 输入密码   192.168.91.135 | success >>{   
"changed": true,    
"key": "ssh-rsa AAAAB3NzaC1yc2EAAAABIwAAAQEArZI4kxlYuw7j1nt5ueIpTPWfGBJoZ8Mb02OJHR8yGW7A3izwT3/uhkK7RkaGavBbAlprp5bxp3i0TyNxa/apBQG5NiqhYO8YCuiGYGsQAGwZCBlNLF3gq1/18B6FV5moE/8yTbFA4dBQahdtVP PejLlSAbb5ZoGK8AtLlcRq49IENoXB99tnFVn3gMM0aX24ido1ZF9RfRWzfYF7bVsLsrIiMPmVNe5KaGL9kZ0svzoZ708yjWQQCEYWp0m+sODbtGPC34HMGAHjFlsC/SJffLuT/ug/hhCJUYeExHIkJF8OyvfC6DeF7ArI6zdKER7D8M0SM  WQmpKUltj2nltuv3w== root@localhost.localdomain",  
"key_options": null,    
"keyfile": "/root/.ssh/authorized_keys",    
"manage_dir": true,    
"path": null,    
"state": "present",    
"unique": false,    
"user": "root"  
}   
[root@test sshpass-1.05]#
2.4 手工复制粘贴的方式

将本地 id_rsa.pub 文件的内容拷贝至远程服务器的~/.ssh/authorized_keys 文件中

阿里云 2 核 2G 服务器 3M 带宽 61 元 1 年,有高配

腾讯云新客低至 82 元 / 年,老客户 99 元 / 年

代金券:在阿里云专用满减优惠券

正文完
星哥说事-微信公众号
post-qrcode
 0
星锅
版权声明:本站原创文章,由 星锅 于2024-07-24发表,共计2405字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中