Linux服务器配置ssh免密登陆多台服务器、服务器别名配置

Linux服务器配置ssh免密登陆多台服务器

  • [一、 生成密钥对](#一、 生成密钥对)
  • [二、 分发公钥](#二、 分发公钥)
  • [三、 测试我免密登陆配置是否成功](#三、 测试我免密登陆配置是否成功)
  • 四、别名配置

本博客不讨论免密登陆的原理,所设计内容非专业术语,只为便于理解及演示如何进行实际操作,如果想了解ssh免密登陆的原理可以参考这篇内容Linux服务器配置ssh免密登陆

如果只是对单机进行操作,也可以参考上面的博客。

一、 生成密钥对

这一步是在控制机,也就是使用这台机器去ssh登陆其他机器。

首先需要检查是否控制机上是否已经生成密钥。

bash 复制代码
ls ~/.ssh/

如果没有看到id_rsa.pub文件则说明控制机上并没有生成密钥对,这里由于要演示完整操作,就假设没有密钥对,如果你的设备上已经有这个文件可以直接跳过这一步。

我们生成新的密钥对。

bash 复制代码
ssh-keygen -t rsa -b 4096

这里 -t rsa参数是指使用rsa加密算法,如果对原理感兴趣可查看Linux服务器配置ssh免密登陆

-b 4096是指使用密钥长度为4096,更安全一些。

输入命令后一路回车(一直按enter键即可)

通过下面命令可以看到多了两个文件id_rsaid_rsa.pub,那么说明密钥已经成功生成了,如上图所示。

其中

  • id_rsa:这个是我们的私钥是不能泄漏的,
  • id_rsa.pub:这个是我们生成的公钥,这个是需要给别人的,也就是需要给我们需要登陆的机器。
bash 复制代码
ls ~/.ssh

二、 分发公钥

由于本文章是对多台服务器进行免密登陆配置所以需要将密钥分发给多台服务器。

这一步我们使用的是ssh-copy-id命令

命令格式如下:

bash 复制代码
ssh-copy-id username@ip

其中username是要远程登陆的服务器账户中的用户名,ip是对应服务器的ip地址。

ssh-copy-id命令会自动将本地~/.ssh/id_rsa.pub追加到需要被登陆的服务器的~/.ssh/authorized_keys文件中。

可以看到执行完ssh-copy-id username@ip应该会出现下面的类似的内容,这就代表免密配置成功了,需要登陆的机器已经认识我们的控制机器了。

多台服务器的只需要将上面的命令重复N即可完成。

三、 测试我免密登陆配置是否成功

直接进行ssh登陆看是否需要输入密码,如果不需要输入密码则免密登陆就配置成功了。

四、别名配置

当我们有多个服务器我们不可能每个服务器的ip地址都记得,还需要记得用户名,这太麻烦了,而且每次登陆都需要输入这么长的内容,很繁琐。

这里我们给服务器配置别名来简化这个过程,这个过程是在操作机器上面进行操作的。

检查 ~/.ssh目录下是否有文件config,如果有这个文件直接进去编辑这个文件即可,如果没有就创建这个文件,我这里是没有的。

bash 复制代码
ls ~/.ssh

使用touch创建这个config文件

bash 复制代码
touch ~/.ssh/config

编辑config文件进行配置

bash 复制代码
Host server
    HostName 192.168.1.101
    User uername
    Port 22

解释一下上面应该怎么配置,Host 后面的server需要把server替换成你想要ssh的别名,也就是说你可以通过ssh server代替ssh username@ip,所以可以讲server替换成一个容易记忆并且比较短的内容

然后下面HostName就填服务器的ip,由于我这里是用的内网进行演示的,所以就是192开头,User后面的username替换成服务器上的用户名,有可能是root,当然这取决于服务器上的用户名到底是什么,Port一般默认是22号端口,如果你进行了替换就填对用的ssh端口号就好了。

根据上面内容,下面是我的配置文件,由于我需要用到ip,所以我这里直接用ip的后面作为别名了。

bash 复制代码
# --- 我的服务器别名 ---

Host 104
    HostName 192.168.1.104
    User node1
    Port 22

Host 105
    HostName 192.168.1.105
    User zc
    Port 22

Host 106
    HostName 192.168.1.106
    User nvidia
    Port 22

可以看到我的三台机器都通过别名成功进行了免密登陆。


至此我们就成功进行了多台服务器的免密登陆配置,以及别名配置,以后就可以清爽登陆服务器啦~~~

🎉🎉🎉完结撒花~~~

相关推荐
聆风吟º6 小时前
CANN开源项目深度实践:基于amct-toolkit实现自动化模型量化与精度保障策略
运维·开源·自动化·cann
Java后端的Ai之路6 小时前
【Python 教程15】-Python和Web
python
Coder个人博客7 小时前
Linux6.19-ARM64 mm mmu子模块深入分析
大数据·linux·车载系统·系统架构·系统安全·鸿蒙系统
冬奇Lab8 小时前
一天一个开源项目(第15篇):MapToPoster - 用代码将城市地图转换为精美的海报设计
python·开源
较劲男子汉9 小时前
CANN Runtime零拷贝传输技术源码实战 彻底打通Host与Device的数据传输壁垒
运维·服务器·数据库·cann
Doro再努力9 小时前
Vim 快速上手实操手册:从入门到生产环境实战
linux·编辑器·vim
wypywyp9 小时前
8. ubuntu 虚拟机 linux 服务器 TCP/IP 概念辨析
linux·服务器·ubuntu
风流倜傥唐伯虎10 小时前
Spring Boot Jar包生产级启停脚本
java·运维·spring boot
二十雨辰10 小时前
[python]-AI大模型
开发语言·人工智能·python
Doro再努力10 小时前
【Linux操作系统10】Makefile深度解析:从依赖推导到有效编译
android·linux·运维·服务器·编辑器·vim