ssh端口转发应用

ssh协议端口转发

  • 本地端口转发

ssh -f -N -L 9527:10.255.254.3:22 60.12.234.102

释义:本地监听9527端口,并且和60.12.234.188建立ssh隧道连接,当访问本地9527的流量会通过隧道转发给60.12.234.102,解密后再转发给10.255.254.3:22这台设备。

示例一
步骤1:本地执行,开启监听9527端口
阿里云

步骤2:连接本地9527端口,这样流量就通过ssh隧道传递到60.12.234.102,经过解密之后再发送给10.255.254.3.

在这里插入图片描述
示例二
步骤1:
这次我们来映射web服务
在这里插入图片描述
步骤2:本地浏览器打开10086端口,效果如下图
在这里插入图片描述

  • 远程端口转发
    ssh -R 9527:192.168.133.1:1880 60.12.234.102
    释义:本地和60.12.234.102建立ssh隧道连接,并在远程开启9527端口,当60.12.234.102收到9527的流量后会通过ssh隧道发送给本地主机,本地主机解密后再转发给192.168.133.1:1880

示例一
步骤1:本地和远程建立ssh连接,并在远程开启9527端口,注意此时的9527端口是在远程主机上开启的,不是在本地了。
本地执行:ssh -R 9527:192.168.133.1:1880 60.12.234.102
在这里插入图片描述
步骤2:远程主机访问自己的9527端口,wing ftp是我自己电脑安装的ftp服务器。
因为远程主机没有浏览器只能通过curl来验证。效果相当于把内网的ftp,发布到远程主机上了。
在这里插入图片描述
示例二
步骤1:本地和远端服务器建立ssh连接,并在远端服务器开启9528端口。
本地执行:ssh -R 9528:192.168.133.1:22 60.12.234.102
在这里插入图片描述
步骤2:远端服务器连接自己的9527端口,流量转发到了192.168.133.1上,是我自己的电脑,并且可以执行相关的命令。

在这里插入图片描述

### Ollama SSH 端口转发配置指南 Ollama 是一种用于管理大型语言模型的工具,但它本身并不直接提供 SSH 功能。然而,可以通过标准的 OpenSSH 配置实现端口转发功能,并将其集成到涉及 Ollama 的工作流中。 以下是关于如何通过 SSH 进行端口转发的相关说明: #### 本地端口转发 当需要将远程服务器上的某个服务暴露给本地计算机时,可以使用以下命令设置本地端口转发: ```bash ssh -L <local_port>:<destination_host>:<destination_port> user@remote_server ``` 在此场景下,`<local_port>` 表示本地监听的端口号,`<destination_host>` 和 `<destination_port>` 则表示目标主机及其开放的服务端口[^2]。 例如,如果希望将运行在 `10.2.2.9` 上的 MySQL 数据库(默认端口为 3306)映射到本地机器上,则可执行如下命令: ```bash ssh -L 3307:10.2.2.9:3306 user@ssh_gateway ``` 这样,在本地访问 `localhost:3307` 就相当于连接到了 `10.2.2.9:3306`。 #### 远程端口转发 对于某些情况下可能需要让外部网络能够访问本机的一个特定服务的情况,可以采用远程端口转发的方式完成此操作: ```bash ssh -R <remote_port>:<source_host>:<source_port> user@remote_server ``` 这里 `<remote_port>` 定义的是远端要绑定的端口;而 `<source_host>` 及其对应的 `<source_port>` 指定源地址和服务端口[^1]。 假设有一款仅限局域网内部使用的 Web 应用程序正在 localhost 的 8080 端口上运行,那么为了让其他同事也能看到这个页面,就可以这样做: ```bash ssh -R 8081:127.0.0.1:8080 colleague@example.com ``` 此时任何向 `colleague.example.com:8081` 发起请求的操作都会被重定向至发起者的个人电脑并返回相应数据。 #### 多节点环境下的无密码 SSH 设置 在一个多节点环境中,为了简化跨节点间通信流程以及提高效率,通常建议预先建立好免密登录机制以便后续自动化脚本调用更加顺畅[^3]。具体做法包括但不限于交换公钥文件等内容。 首先确认当前用户的 .ssh 文件夹是否存在 id_rsa.pub 类型的公开密钥材料,如果没有则先创建一对新的 RSA 密码对儿: ```bash ssh-keygen -t rsa -b 4096 -C "your_email@example.com" ``` 接着把生成出来的 public key 添加进每一个目标设备中的 authorized_keys 文档里头去: ```bash cat ~/.ssh/id_rsa.pub | ssh user@target_node 'mkdir -p ~/.ssh && cat >> ~/.ssh/authorized_keys' ``` 最后测试一下能否成功达成无需输入额外验证信息即可顺利完成整个链接过程的效果: ```bash ssh target_node ``` 如果一切正常的话应该可以直接跳转过去而不必再手动填写账号密码之类的信息了。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值