一、场景举例(为啥需要免密连接)
1.服务集群间文件复制、通信
2.执行定时触发自动化脚本
3.本地连接远程服务器操作
服务器台数有很多,以上举例都是属于服务器之间的通信,如果每次执行上面操作都要输入账号密码岂不是效率太高了,容易被开除。
ssh默认端口号是22,当然也可以自行指定,这么可靠性的功能传输层肯定是TCP协议
二、执行命令
1.我host连接你host(默认方式)
默认是用我的用户名去连接你host
假设我host有'wocao' 用户,默认我host的wocao连你是用wocao用户名的,但是你服务器里没有用户叫wocao,所以得在你服务器创建个用户叫'wocao'
(1)新增用户命令:
adduser wocao -- 新增用户wocao
passwd wocao -- 为wocao用户设置密码
data:image/s3,"s3://crabby-images/3d0db/3d0dbb8fe891dcfdb583f18ad6793b9977691151" alt=""
好了已经创建好了wocao用户在你host了,所以我现在要wocao连接你wocao用户了
(2)创建公钥密钥
bash
ssh-keygen -t rsa -b 4096
-t:加密方式 -b:密钥长度位数
输入完然后一路回车即可结束
data:image/s3,"s3://crabby-images/4e288/4e288efe2904b98ded703727b3f1b3b42b790941" alt=""
其他加密方式请ssh-keygen help来查看(选读)
data:image/s3,"s3://crabby-images/60ae2/60ae23f344f26932fcffbbae687bd14cc2609ea0" alt=""
进入目录查看公钥密钥是否生成(下图红框即为完成)
bash
cd /home/wocao/.ssh
ls
data:image/s3,"s3://crabby-images/f6492/f6492bd45f92b34a9f221c7c4e3312505a8dcded" alt=""
(3)上传公钥到目标服务器
把(源)我的公钥上传到你服务器(目标)
bash
ssh-copy-id [目标IP、域名]
此时在目标主机上可以看到你上传的公钥
data:image/s3,"s3://crabby-images/323ac/323acc99fb86e4bc7d51274076402242dc56eee6" alt=""
data:image/s3,"s3://crabby-images/90489/90489497bd31645d96e80476c4f61d55f6fd76f7" alt=""
(4)ssh连接
bash
ssh [ip]或[域名]
data:image/s3,"s3://crabby-images/cf31e/cf31e4ccbee60a3e527a11fd8fa46b2dcf10a40d" alt=""
主机名变了证明我已经使用的是你的wocao用户了,我这里主机名是node1变成了你的node2
此时我可以打开一个新的ssh窗口连接我host,不耽误上面的连接你的ssh
退出ssh命令: 可以发现主机名又变了回来
bash
exit
data:image/s3,"s3://crabby-images/7067d/7067dbef93622afa57cf5cb5c278cd6a8143c1f4" alt=""
2.我host连接你host(指定账户方式)
(1)为我的主机创建公钥密钥
我连接你,得我创建(host1连接host2得host1的用户创建公钥私钥)
bash
ssh-keygen -t rsa -b 4096
-t:加密方式 -b:密钥长度位数
输入完然后一路回车即可结束
data:image/s3,"s3://crabby-images/4e288/4e288efe2904b98ded703727b3f1b3b42b790941" alt=""
(2)上传公钥到目标服务器
把(源)我的公钥上传到你服务器(目标)
bash
ssh-copy-id [目标IP、域名]
data:image/s3,"s3://crabby-images/46b01/46b0190fe2ff37ff743c42f0bc23082f9ea54aa7" alt=""
(3)ssh指定账户登录
bash
ssh [账户名]@[主机IP、域名]
data:image/s3,"s3://crabby-images/b2a8a/b2a8ab922269934f482b463a62d6ff438819e20a" alt=""
如果你host1通过 SSH 登录到 host2 ,并且一直保持连接(即不退出),那么在这段时间内,host1 的用户 (例如 user1
)相当于拥有了 host2 的用户 (例如 user2
)的权限。你可以在 host2 上执行所有 user2 用户的操作,直到你退出该 SSH 会话(通过 exit
或断开连接)。
三、其他信息(上面仅为操作)
1.指纹
data:image/s3,"s3://crabby-images/90761/90761bd8841df0832eb7baaa785acf1a1c5bfb4e" alt=""
host1想连接host2(目标主机),host2会发给host一段指纹供host1确认身份,host2发来的指纹是将/etc/ssh目录下的公钥生成的哈希值(sha256和md5)告诉host2确认
data:image/s3,"s3://crabby-images/2ea63/2ea6345f30d57442c3d38ee6ef7f43377d04f2c0" alt=""
如果输入yes,证明你信任该指纹,会把它存到know_hosts文件,以后host1再连接host2时就不用验证指纹了
data:image/s3,"s3://crabby-images/b9429/b942926c85f76fb725ee763bbc6ccdffe48bc372" alt=""
上次exit后尝试第二次连接 :发现不用再次输入yes信任host2指纹了,只输入密码即可
data:image/s3,"s3://crabby-images/b3555/b355589e55fc39dd223a7783a7add9fcdf3caccc" alt=""
2.host1公钥发送
私钥 用于 host1 进行身份验证,保持在 host1
公钥 用于 host2 验证 host1 的身份,必须复制到 host2 的 authorized_keys
文件中
data:image/s3,"s3://crabby-images/323ac/323acc99fb86e4bc7d51274076402242dc56eee6" alt=""
data:image/s3,"s3://crabby-images/2b6b7/2b6b735c3ae48d5294fc636ba307ee1763f949aa" alt=""