ssh端口转发

本文介绍了一种通过SSH端口转发实现跨网络访问的方法。在三台Linux PC组成的环境中,利用SSH端口转发让Client A能够间接访问Server C提供的Web服务。文章详细记录了各主机的配置步骤及通道构建过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

ssh端口转发

 

三台linux—PC机,host-B需要两块网卡,host-B能够分别与host-Ahost-C通信,AC之间无法通信,现在客户机A想要访问Cweb服务,故通过ssh端口转发来实现此功能。

一,基本配置

host-A:

1.Service sshd restart     -------》开启ssh服务

2.Iptables -F               ------》清空防火墙规则

3.Setenforce 0            ------》关闭selinux

4.Service NetworkManager stop  -----》不关闭service network restart 会报错

5.修改eth0 地址 vim /etc/sysconfig/network-scrips/ifcfg-eth0  192.168.1.1/24

 

host-B

1.Service sshd restart     -------》开启ssh服务

2.Iptables -F               ------》清空防火墙规则

3.Setenforce 0            ------》关闭selinux

4.Service NetworkManager stop  -----》不关闭service network restart 会报错

5.修改eth0 地址 vim /etc/sysconfig/network-scrips/ifcfg-eth0   192.168.1.2/24

  修改eth1 地址 vim /etc/sysconfig/network-scrips/ifcfg-eth1   142.1.1.1/24

 

host-C

1.service httpd restart     ------》开启http服务

2.Service sshd restart     -------》开启ssh服务

3.Iptables -F               ------》清空防火墙规则

4.Setenforce 0             ------》关闭selinux

1.     Service NetworkManager stop  -----》不关闭service network restart 会报错

2.     修改eth0 地址 vim /etc/sysconfig/network-scrips/ifcfg-eth0

   142.1.1.2/24

二,构建ssh通道

host-A

 ssh -L 8080:142.1.1.2:80 root@192.168.1.3

三,测试

在浏览器中输入http://127.0.0.1:8080

 


### 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、付费专栏及课程。

余额充值