共计 1139 个字符,预计需要花费 3 分钟才能阅读完成。
导读 | 如果你使用多个 ssh 连接,管理和记住 IP 地址、用户名和密码、秘钥会有点困难。在本指南中,将学习使用 ssh 的配置文件,该文件存储 ssh 连接所需的所有信息。 |
创建配置文件并添加主机信息
每台基于 Linux / Unix 的机器都有一个 .ssh
文件夹,您可以在其中保存 ssh 密钥。在这个文件夹中,你可以创建一个名为 config
的文件,可以将所有远程机器的详细信息放在这个配置文件中。
现在使用以下命令在 .ssh
文件夹中创建一个配置文件,如果用户主目录中没有 .ssh
文件夹,需要创建一个。
[root@localhost ~]# mkdir ~/.ssh
[root@localhost ~]# touch ~/.ssh/config
下面是一个简单的实例:
[root@localhost ~]# vim ~/.ssh/config
Host mysql
HostName 192.168.0.12
Port 22
User root
IdentityFile ~/.ssh/common_pri_key
Host web
HostName 192.168.43.137
Port 5658
User bob
Host node1
HostName 192.168.43.131
Port 22
User root
上面配置中,设置每台服务器的连接名称,连接地址,端口号,用户名,还可以指定秘钥文件。如果服务器没有域名,可以提供 IP 地址。
连接测试
现在已经设置了连接到远程机器所需的所有配置。现在需要连接,只需要使用 ssh
命令后面加上在配置文件中指定的 Host
名称即可连接。
[root@localhost ~]# ssh mysql
因为 Host mysql
我已经提前设置好免密登录,所以不需要输入密码就可以连接了。
定义常用参数
如果需要管理大量服务器,并且所有服务器都具有相同的用户名和 ssh 密钥。在这种情况下,可以使用正则表达式定义一组公共参数。如下:
Host dev
Hostname 192.168.43.137
Host web.node1
Host web.node2
Host *
Port 4556
User jordan
IdentityFile ~/.ssh/jordan_privatekey
Host web*
Port 4668
User james
IdentityFile ~/.ssh/james_privatekey
在上面的示例中 Host *
表示该块中描述的参数适用于全局的服务器。Host web*
该块中描述的参数适用于所有以 web 开头的主机定义。
Host
部分指定的主机名称如果不能解析,可以在下面指定一个 Hostname 参数,并写入他的 ip 地址。如果 Host 指定的主机名称能被解析,可以不添加 Hostname
参数。
总结
本指南中我们学习了如何使用 ssh 的配置文件,该文件存储 ssh 连接所需的所有信息。
正文完
星哥玩云-微信公众号