利用WSL2的镜像功能访问Windows下的所有网卡

目录

引言

镜像功能

如何设置

自动代理

结语


引言

我通常用PC上的LAN口去连接开发板,但是在WSL2中要访问LAN口连接的开发板有点麻烦。WSL2默认的网络模式为NAT,如果要访问Windows中网口需要设置桥接,比较繁琐。今天尝试了一下Windows 11的镜像网络功能,觉得非常方便,推荐给大家。

镜像功能

镜像网络的官方说明在这里:Accessing network applications with WSL | Microsoft Learn

在运行 Windows 11 22H2 及更高版本的计算机上,你可以在.wslconfig 文件的 [wsl2] 部分下设置 networkingMode=mirrored(网络模式=镜像模式),以启用镜像模式网络。启用此功能会将 WSL(适用于 Linux 的 Windows 子系统)切换到全新的网络架构,其目标是将你在 Windows 上的网络接口 “镜像” 到 Linux 中,从而添加新的网络功能并提高兼容性。

以下是启用此模式目前带来的好处:

1. IPv6 支持

2. 使用本地主机地址 127.0.0.1 从 Linux 内部连接到 Windows 服务器。不支持 IPv6 本地主机地址 ::1。

3. 提高了 VPN(虚拟专用网络)的网络兼容性

4. 组播支持

5. 直接从你的局域网 (LAN) 连接到 WSL

简单的说,一般在WSL2中得到的是一个172开头的IP地址,而采用了镜像网络之后,所有Windows的网口都被映射到WSL2中,就像下面这样: 

test@ERAZE-UHYFLAFVU:~$ ifconfig
eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        inet 192.168.137.1  netmask 255.255.255.0  broadcast 192.168.137.255
        inet6 fe80::f764:e9f6:65e6:4967  prefixlen 64  scopeid 0x20<link>
        ether 68:1d:ef:3c:97:5b  txqueuelen 1000  (Ethernet)
        RX packets 0  bytes 0 (0.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 5  bytes 450 (450.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

eth1: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1472
        inet 192.168.1.216  netmask 255.255.255.0  broadcast 192.168.1.255
        inet6 2408:8207:193f:d350:61e5:681e:ac74:e19c  prefixlen 128  scopeid 0x0<global>
        inet6 2408:8207:193f:d350:a9a9:9da:93ff:14f6  prefixlen 64  scopeid 0x0<global>
        inet6 fe80::4991:3d61:ea7c:b92d  prefixlen 64  scopeid 0x20<link>
        ether b0:ac:82:86:46:8b  txqueuelen 1000  (Ethernet)
        RX packets 0  bytes 0 (0.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 11  bytes 1170 (1.1 KB)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

lo: flags=73<UP,LOOPBACK,RUNNING>  mtu 65536
        inet 127.0.0.1  netmask 255.0.0.0
        inet6 ::1  prefixlen 128  scopeid 0x10<host>
        loop  txqueuelen 1000  (Local Loopback)
        RX packets 0  bytes 0 (0.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 0  bytes 0 (0.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

loopback0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500
        ether 00:15:5d:13:a7:dc  txqueuelen 1000  (Ethernet)
        RX packets 0  bytes 0 (0.0 B)
        RX errors 0  dropped 0  overruns 0  frame 0
        TX packets 0  bytes 0 (0.0 B)
        TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

现在的eth0是我的LAN口,而eth1是WLAN。 

而现在我就可以直接访问开发板了:

如何设置

在Windows的用户文件夹(如果用户名为 “JohnDoe”,那么就是 “C:\Users\JohnDoe”)下的`.wslconfig`文件中填入以下配置(如果没有该文件,就创建一个):

[experimental]
networkingMode=mirrored

然后使用wsl --shutdown命令关闭WSL2实例。在下次打开WSL2的时候,镜像网络就配置好了。

自动代理

在运行 Windows 11 22H2 及更高版本的计算机上,在 .wslconfig 文件的 [wsl2] 部分下设置 autoProxy=true,可强制 WSL使用 Windows 的 HTTP 代理信息。

[wsl2]
autoProxy=true

如果你已在 Windows 中设置了代理,启用此功能后,该代理也会在 WSL 中自动设置。这对于从Github下载软件非常方便。

有关更多的WSL2设置可以参考:Advanced settings configuration in WSL | Microsoft Learn

结语

以上就是关于WSL镜像模式网络和自动代理功能的详细介绍啦!无论是想要优化网络兼容性、解锁新的网络特性,还是简化代理配置流程,这些设置都能为你的WSL使用体验带来显著提升。如果你在实践过程中遇到任何问题,或者发现了更多实用技巧,欢迎在评论区分享交流。探索WSL的更多可能性永无止境,期待大家都能在Windows与Linux的融合世界里,找到最适合自己的高效工作与开发方式!

后记

我有个学生提醒我,现在有个应用WSL Settings可以专门来修改参数,不需要再修改配置文件了。嗯,确实好用!

<think>好的,用户现在问的是关于WSL2网络模式中的“镜像”是什么意思,以及它的功能、特性和与NAT的区别。我需要先回顾之前对话的内容。之前用户是在设置WSL2中的Docker服务让局域网访问,涉及到了端口转发和NAT的问题。现在用户可能对WSL2网络模式产生了更深的兴趣,尤其是镜像模式。 首先,我需要确认自己对WSL2网络模式的理解是否正确。WSL2默认使用NAT模式,通过虚拟交换机连接,而Hyper-V的镜像网络模式可能是一个更高级的功能。用户可能遇到了网络配置上的问题,或者想优化网络性能,所以想了解镜像模式的作用。 接下来,我需要查找微软的官方文档或者可靠的技术博客,确认镜像网络模式的具体定义和功能。根据记忆,镜像模式可能允许WSL2实例直接使用宿主机的网络接口,省去NAT的转换,从而获得更好的性能和更简单的配置。但需要验证这一点。 然后,需要对比镜像模式和NAT模式的不同点。NAT模式下,WSL2有一个内部虚拟网络,通过宿主机进行地址转换,而镜像模式可能让WSL2实例直接暴露在物理网络中,获得独立的IP地址,类似桥接模式。但需要确认是否镜像模式等同于桥接,或者有其他差异。 用户可能的需求是希望WSL2中的服务能够更方便地被局域网访问,而不需要复杂的端口转发。之前用户已经通过端口转发实现了访问,但可能发现每次WSL2重启IP变化导致需要更新转发规则,而镜像模式可能解决这个问题,提供更稳定的网络配置。 同时,需要注意用户提到的“不能更改docker compose文件”和“不能将WSL网络模式改为bridge”的限制,所以用户可能在寻找替代方案,比如镜像模式是否可以在不修改现有配置的情况下提供更好的网络支持。 需要指出镜像模式的优缺点,比如是否需要Windows 11特定版本,是否支持IPv6,性能如何,配置复杂度等。另外,要明确镜像模式和NAT的主要区别,比如IP分配、网络拓扑、使用场景等。 最后,总结镜像模式的功能和适用情况,帮助用户判断是否适合他们的需求,比如是否需要直接暴露服务到局域网,或者是否有更高的网络性能需求。同时,提醒用户可能的兼容性和系统要求,避免他们尝试在不支持的环境下配置。</think>以下是WSL2网络模式中“镜像网络”(Mirrored Networking)的详细解析,及其与NAT模式的核心区别: --- ### 一、镜像网络(Mirrored Networking)的定义与功能 1. **基本概念** 镜像网络是**Windows 11 Build 22518及以上版本**引入的WSL2高级网络模式,通过**Hyper-V虚拟交换机**实现**网络接口直接映射**。 其核心特性是让**WSL2实例直接共享宿主机的物理网络接口**,而非通过传统的NAT隔离。 2. **核心功能** - **IP地址直接暴露** WSL2实例获得与宿主机**同一物理网络**的独立IP地址(如局域网的`192.168.1.x`),与宿主机平级。 - **消除NAT层** 网络流量直接通过物理网卡收发,无需宿主机进行地址转换。 - **支持复杂协议** 原生支持**组播(Multicast)**、**IPv6**等NAT模式下受限的协议。 - **简化端口转发** 服务可直接通过WSL2的IP+端口被局域网访问,无需手动配置端口转发规则。 --- ### 二、镜像网络 vs NAT模式对比 | **特性** | **镜像网络** | **NAT模式** | |-------------------------|---------------------------------------------|---------------------------------------------| | **网络拓扑** | WSL2实例与宿主机平级,类似桥接(Bridged) | WSL2实例位于虚拟子网,宿主机作为网关(类似路由器) | | **IP地址分配** | 从物理网络DHCP获取独立IP(如`192.168.1.100`) | 固定虚拟子网IP(如`172.24.0.2`) | | **局域网可见性** | WSL2实例直接暴露在局域网,可被其他设备直接访问 | 需通过宿主机端口转发才能访问 | | **协议支持** | 完整支持IPv6、组播、ICMP | 仅支持IPv4和单播,组播/ICMP受限 | | **性能** | 更高(减少NAT转换开销) | 较低(存在NAT层处理延迟) | | **配置复杂度** | 需手动启用镜像模式,依赖物理网络环境 | 开箱即用,无需额外配置 | --- ### 三、镜像网络的典型应用场景 1. **局域网服务直连** 在WSL2中运行Web服务器/Docker容器时,其他设备可直接通过WSL2的IP访问,无需配置宿主机端口转发。 ```bash # 示例:在WSL2中启动服务后,局域网设备访问 http://192.168.1.100:8000 # 假设WSL2获取的IP为192.168.1.100 ``` 2. **跨设备开发测试** 支持手机、平板等设备直接调试WSL2内的服务,适用于物联网(IoT)开发。 3. **网络协议调试** 需要测试组播、IPv6或原始套接字的场景(如视频流、P2P应用)。 --- ### 四、镜像网络的启用方法 1. **系统要求** - Windows 11 Build 22518或更高版本 - 物理网络支持DHCP(通常家庭/企业网络均满足) 2. **配置步骤** ```powershell # 1. 创建或修改WSL配置文件 code "$env:USERPROFILE/.wslconfig" # 2. 添加以下内容启用镜像网络 [experimental] autoMemoryReclaim=gradual networkingMode=mirrored # 3. 重启WSL实例 wsl --shutdown ``` --- ### 五、注意事项 1. **IP地址稳定性** WSL2实例的IP可能随物理网络DHCP租约更新而变化,建议在路由器中绑定静态IP。 2. **安全性风险** 直接暴露在局域网可能增加攻击面,需确保WSL2内防火墙(如`ufw`)已启用。 3. **兼容性限制** 部分企业网络可能因MAC地址过滤或端口安全策略导致镜像网络不可用。 --- ### 六、总结 - **选择镜像网络**:需直接暴露服务、减少NAT开销、支持高级协议时优先使用。 - **选择NAT模式**:适用于简单开发、无需局域网直连、追求开箱即用的场景。 - **混合方案**:可通过`docker run -p 0.0.0.0:端口:端口`在NAT模式下实现部分镜像网络的便利性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

神一样的老师

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值