同一子网内的其他主机监听本机WSL2的特定端口
前提说明:
\quad\quad
实验室内网中的主机,其ipv4
地址都是192.168.22.x
;而本机上的WSL2
,其ipv4
地址为172.30.x.x
。二者处于不同的私网内,所以一般局域网内的其他主机是不能直接访问本机上WSL2
的ipv4
地址,进行 HTTP
通信的。
\quad\quad
解决思路:
Windows
主机可以与同一子网内的其他主机进行通信;Windows
主机还可以同时和WSL2
子系统进行通信;- 能不能通过
Windows
主机作为中继,将WSL2
的端口映射出来?
\quad\quad 答案是可行的,可以通过Windows
中的netsh interface portproxy
命令做到!
步骤
1. 获取WSL2的IPv4地址
\quad\quad
首先要获取想要映射出来的端口号以及WSL2
的IPv4
地址信息。端口号就是应用的端口号,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
配置文件相关配置项,上述方法也只是我测试成功的一种方法,并不保证在各种情况下都能成功。