同一子网内的其他主机监听本机WSL2的特定端口

前提说明:

\quad\quad 实验室内网中的主机,其ipv4地址都是192.168.22.x;而本机上的WSL2,其ipv4地址为172.30.x.x。二者处于不同的私网内,所以一般局域网内的其他主机是不能直接访问本机上WSL2ipv4地址,进行 HTTP通信的。
\quad\quad 解决思路:

  1. Windows主机可以与同一子网内的其他主机进行通信;
  2. Windows主机还可以同时和WSL2子系统进行通信;
  3. 能不能通过Windows主机作为中继,将WSL2的端口映射出来?
    \quad\quad 答案是可行的,可以通过Windows中的netsh interface portproxy命令做到!

步骤

1. 获取WSL2的IPv4地址

\quad\quad 首先要获取想要映射出来的端口号以及WSL2IPv4地址信息。端口号就是应用的端口号,IP地址可以通过ifconfig命令获得。

## 方法一:直接找
ifconfig  # shell中输入该命令回车后,手动查找IP地址

## 方法二:过滤一下
ifconfig | grep eth0 -n1 # 第一种方法一般会输出大量信息,造成干扰

2. 建立转发映射

\quad\quad 以管理员身份运行cmd,然后输入下述命令:

netsh interface portproxy add v4tov4 ^
listenaddress=0.0.0.0 listenport=<port number you want to expose> ^
connectaddress=<wsl ip addr> connectport=<port number in wsl>

\quad\quad 此步过后,192.168.x.x子网内的其他主机,便可通过Windows主机在192.168.x.x子网内的地址+上述命令的<listenport>端口号,间接地访问到WSL2中的应用。

3. 删除映射转发关系

\quad\quad 如果想重建映射关系或者不再使用并删除映射关系,可执行

netsh interface portproxy delete v4tov4 ^
listenaddress=0.0.0.0 listenport=<port number you want to expose>

总结

\quad\quad 如何对外暴露WSL2中的应用端口,方法不止一种,例如还可以修改User文件夹中的.wslconfig配置文件相关配置项,上述方法也只是我测试成功的一种方法,并不保证在各种情况下都能成功。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值