SSH 穿越多个跳板机的连接方法

简介: SSH 穿越多个跳板机的连接方法

鉴于安全原因,工作需要使用跳板机登录;鉴于服务器环境老旧,我需要在服务器上使用 docker 来搞个开发环境,所以需要有一种方法穿越层层阻隔,让我的 vscode 直接连过去。


SSH 公钥和私钥


  • 首先搞清楚一些基本关系,一般使用密钥登录,ssh-keygen -t rsa 运行此命令产生公钥私钥(id_rsa 和 id_rsa.pub),一路回车可以不设置保护密码,假设要登录的机器是 server,登录的终端是 client,那么将公钥 id_rsa.pub 的内容记录在 server 的 authorized_keys 中,然后 client 使用私钥 id_rsa 登录。
  • 每一个被登录的机器都开启的 ssh 服务,并配置了 ssh 密钥登录功能。对于我的需求来说,公司的跳板机和服务器一定是已经配置的,否则无法登录服务器,因此我还需要在 docker 中配置 ssh 密钥登录服务。
  • client 设置登录的层层专跳(这是重点)

ssh 相关的文件如果没有特殊说明,都是在 ~/.ssh 文件夹中,ssh 服务的配置文件在 /etc/ssh/sshd_config 中。

##openssh 的 ProxyJump

在 openssh7.5 之后(ubuntu18.04),支持 ProxyJump 语句,非常方便。windows 不支持。

假设我们登录路径是这样的:

client->jump_server->server->dev_docker

那么 client 的 ~/.ssh/config 文件应该如下:


Host jump
    HostName <jump_server ip>
    Port <jump_server port>
    User <jump_server username>
    IdentityFile <jump_server id_rsa>
Host server
    HostName <server ip>
    Port <server port>
    User <server username>
    IdentityFile <server id_rsa>
    ProxyJump jump
Host dev_docker
    HostName <dev_docker ip>
    Port <dev_docker port>
    User <dev_docker username>
    IdentityFile <dev_docker id_rsa>


代码中有三个主机配置,分别是 jumpserverdev_docker。每个主机都有不同的 IP 地址、端口、用户名和身份验证文件等信息。

其中,jump 配置使用了 SSH 的跳板代理(ProxyJump)功能,它可以让你通过跳转到一个中转服务器(jump_server)来连接远程服务器(server)。ProxyJump jump 选项就是表示使用 jump 作为跳板代理。

每个主机配置的具体细节如下:

  • jump:指定中转服务器的 IP 地址、端口、用户名和身份验证文件等信息。
  • server:指定远程服务器的 IP 地址、端口、用户名和身份验证文件等信息,同时借助 ProxyJump 选项指定了使用跳板代理连接该服务器。
  • dev_docker:指定 Docker 容器内的开发环境的 IP 地址、端口、用户名和身份验证文件等信息。

这样,在实际使用 SSH 客户端连接每个主机时,只需要使用对应的别名(即 Host 参数的值),SSH 客户端就会自动读取 ~/.ssh/config 文件中的配置信息,并使用这些选项连接相应的主机,从而节省了很多输入连接参数的时间和精力。

然后在 client 中,直接使用 ssh dev_docker 命令,ssh 就会一步步登录过去。使用 -v 可以看到每一步的登录过程。

vscode 会自动读取 config 文件,就可以直接打开 docker 中的文件夹了。真的很方便。

还有两个比较实用的配置,同样是配置在客户端:

  • ServerAliveInterval 60:每隔 60s 服务器发送一个包看客户端是否有响应。
  • ServerAliveCountMax 600:服务器发出请求后客户端没有响应的次数达到一定值,就自动断开,正常情况下,客户端不会不响应。

这两个配置组合就可以保持 ssh 的长连接了,不用一直手动连接。

目录
相关文章
|
4月前
|
Linux 网络安全 Docker
windows ssh连接docker 容器
windows ssh连接docker 容器
99 0
|
5月前
|
网络安全
idea配置远程服务器实现远程编辑文件及ssh连接
idea配置远程服务器实现远程编辑文件及ssh连接
118 0
|
6月前
|
关系型数据库 MySQL 网络安全
mysql只能通过ssh通道连接到内网,如何创建只能访问MySQL的SSH用户
mysql只能通过ssh通道连接到内网,如何创建只能访问MySQL的SSH用户
334 0
|
6月前
|
存储 安全 Linux
在 Linux 上保护 SSH 服务器连接的 8 种方法
本文主要介绍了8种提高SSH协议安全性的方法,这些在实际工作中其实是都会有所用到的,比如服务器基线啥的,希望大家一起努力维护好自己的服务器。另注:本文为转载,版权为原作者所有https://www.linuxmi.com/secure-ssh-connections-linux.html,侵删。
|
7月前
|
弹性计算 jenkins 持续交付
|
6月前
|
Ubuntu Linux 网络安全
SSH客户端连接远程服务器
一、什么是客户端连接远程服务器 发起连接的一方,计算机或设备(称为客户端)与另一个计算机或设备(称为远程服务器)建立连接。 客户端通过网络连接到远程服务器,远程服务器则是提供所需服务或资源的一方。 客户端通常使用特定的协议(如SSH、HTTP、FTP等)与远程服务器进行通信。 示例:你使用SSH客户端从本地计算机连接到远程服务器以执行远程命令。 二、什么是服务端连接远程服务器
204 1
|
6月前
|
运维 应用服务中间件 网络安全
Ansible自动化运维工具之解决SSH连接使用明文密码问题(4)
Ansible自动化运维工具之解决SSH连接使用明文密码问题(4)
|
7天前
|
网络协议 安全 Linux
IDEA通过内网穿透实现固定公网地址远程SSH连接本地Linux服务器
IDEA通过内网穿透实现固定公网地址远程SSH连接本地Linux服务器
|
5月前
|
Cloud Native 网络安全 Go
SSH连接服务器后执行多条命令
SSH连接服务器后执行多条命令
|
1月前
|
安全 Shell 网络安全
如何通过SSH连接云服务器
当你购买云服务器后,你可以通过SSH方式安全的连接到你的云服务器,因为只有你连上云服务器后才能进行服务器相关的配置操作。这里分别介绍了MAC用户和Windows用户如何通过SSH连接云服务器。
261 1
如何通过SSH连接云服务器