Windows11系统配置WSL2网络使它支持LAN访问

2024-05-14 22:52

本文主要是介绍Windows11系统配置WSL2网络使它支持LAN访问,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档

文章目录

  • 前言
  • 一、WSL2安装
  • 二、使用步骤
    • 1.NAT
    • 2.镜像
  • 三、写在最后
  • 总结


前言

WSL2的出现感觉真的是一个惊喜,又想玩Linux,又怕日用搞不了的最佳替代方案。而且经过测试WLS2除了IO性能略弱以外,其它的性能损失的真不多。生产力几乎全线支持,甚至核AI开发息息相关的CUDA也支持。

我曾经好几次使用Windows+WSL2的组合解决很多问题,今天就重点说下WSL2的网络问题,给不太懂的小伙伴提供点有价值的经验。


一、WSL2安装

这里只说网络配置,安装我的其它帖子有,不会的可以先移步看下教程。

二、使用步骤

SSH(默认22端口)当例子,当然现实可能使用Nginx代理的情况更多,原理是一样的。目前WSL2支持两种方式允许LAN访问。所谓LAN访问就是跟你的Windows主机一个局域网的设备直接访问WSL2,就相当于替代了完整的Linux的功能。

1.NAT

网路地址转换,这个是默认支持的方式。Windows为WSL2的实例创建了一个虚拟网卡,这个虚拟网卡和Windows的物理网卡不是一个,但是它们可以互通

你再WSL2实例里面使用ifconfig看下网卡信息会发现一般都是172开头的,显然和你的Windows以太网卡不是一个网段。

eth0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500inet 172.24.34.81  netmask 255.255.240.0  broadcast 172.24.47.255inet6 fe80::215:5dff:fe11:5b4  prefixlen 64  scopeid 0x20<link>ether 00:15:5d:11:05:b4  txqueuelen 1000  (Ethernet)RX packets 221  bytes 187749 (187.7 KB)RX errors 0  dropped 0  overruns 0  frame 0TX packets 107  bytes 9147 (9.1 KB)TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0lo: flags=73<UP,LOOPBACK,RUNNING>  mtu 65536inet 127.0.0.1  netmask 255.0.0.0inet6 ::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 0TX packets 0  bytes 0 (0.0 B)TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

这个时候你可以在Windows里面访问WSL2的任何端口,但是和你的Windows设备同网段的设备不能访问WSL2的端口,哪怕你在WSL2里面绑定的是全地址也不行,比如*:22

COMMAND PID USER   FD   TYPE DEVICE SIZE/OFF NODE NAME
sshd    229 root    3u  IPv4  17708      0t0  TCP *:ssh (LISTEN)
sshd    229 root    4u  IPv6  17710      0t0  TCP *:ssh (LISTEN)

办法还是有的,巨硬已经给我们了。没错,就是通过Windows端口映射WSL2里面的端口到Windows本地,当然Windows也得配全地址

具体命令如下:

注意:需要管理员权限!

netsh interface portproxy add v4tov4 listenport=4000 listenaddress=0.0.0.0 connectport=22 connectaddress=(wsl hostname -I)

字段解释:

netsh interface portproxy add v4tov4:这个是添加IPV4地址的意思,保持不变。
listenport:Windows的代理端口,LAN访问通过这个端口
listenaddress:Windows代理的地址,0.0.0.0是全地址,还可以指定地址,但一定是可访问的
connectport:WSL2里面绑定的端口,比如SSH
connectaddress:WSL2的实例的IP地址,你也可以通过ifconfig查看并指定绑定哪个地址

配置好后就是下面的样子:

在这里插入图片描述

注意:Windows映射的端口不能被其它程序占用,否则失败!

2.镜像

这个网络架构是后来出的,不是所有的版本都支持的,需要Windows11 22H2+版本才行。它的方案和NAT完全不是一回事,它将 Windows 上的网络接口“镜像”到 Linux 中,以添加新的网络功能并提高兼容性。

要使用这个功能你需要在Windows的用户目录创建一个文件,名字叫.wslconfig。它的名字就叫.wslconfig,没有其它的后缀什么的。然后再里面配置以下命令:

# Settings apply across all Linux distros running on WSL 2
[wsl2]#如果值为 mirrored,则会启用镜像网络模式。 默认或无法识别的字符串会生成 NAT 网络。
networkingMode=mirrored
#networkingMode=NAT

配置好之后一定要执行wsl --shutdown,然后再重新启动WSL2实例。启动完成后你看到的网络配置长下面这样:

eth2(或者叫其它的名字)就是你的Windows的以太网的镜像,它的IP地址和你的Windows地址一模一样。

eth2: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500inet 10.0.20.52  netmask 255.255.255.0  broadcast 10.0.20.255inet6 fe80::9672:e4cf:652d:1d8a  prefixlen 64  scopeid 0x20<link>ether 70:b5:e8:88:0d:5e  txqueuelen 1000  (Ethernet)RX packets 38  bytes 13077 (13.0 KB)RX errors 0  dropped 0  overruns 0  frame 0TX packets 53  bytes 6194 (6.1 KB)TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0lo: flags=73<UP,LOOPBACK,RUNNING>  mtu 65536inet 127.0.0.1  netmask 255.0.0.0inet6 ::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 0TX packets 0  bytes 0 (0.0 B)TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0loopback0: flags=4163<UP,BROADCAST,RUNNING,MULTICAST>  mtu 1500ether 00:15:5d:c0:0c:af  txqueuelen 1000  (Ethernet)RX packets 0  bytes 0 (0.0 B)RX errors 0  dropped 0  overruns 0  frame 0TX packets 0  bytes 0 (0.0 B)TX errors 0  dropped 0 overruns 0  carrier 0  collisions 0

这个模式除了需要Windows11 22H2这个硬性要求外,几乎不需要额外配置,你在WSL2里面绑定的任何端口都可以通过LAN直接访问*

注*:防火墙配置必须能够放行,以后再讨论防火墙问题,很多人可能不会在WSL2里面配置防火墙,保持默认即可。

三、写在最后

不管哪种方式配置,注意你都是共用Windows的以太网带宽,你要注意带宽瓶颈。只能说这种方式提供一种测试的或小型网络需求,但是无疑给你提供了非常好的测试平台,你只需要一台支持WSL2的Windows电脑就搞定了。


总结

1、目前只支持这两种方式,后续有新的再说。

这篇关于Windows11系统配置WSL2网络使它支持LAN访问的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/990082

相关文章

关于Java内存访问重排序的研究

《关于Java内存访问重排序的研究》文章主要介绍了重排序现象及其在多线程编程中的影响,包括内存可见性问题和Java内存模型中对重排序的规则... 目录什么是重排序重排序图解重排序实验as-if-serial语义内存访问重排序与内存可见性内存访问重排序与Java内存模型重排序示意表内存屏障内存屏障示意表Int

SpringBoot实现基于URL和IP的访问频率限制

《SpringBoot实现基于URL和IP的访问频率限制》在现代Web应用中,接口被恶意刷新或暴力请求是一种常见的攻击手段,为了保护系统资源,需要对接口的访问频率进行限制,下面我们就来看看如何使用... 目录1. 引言2. 项目依赖3. 配置 Redis4. 创建拦截器5. 注册拦截器6. 创建控制器8.

SpringBoot如何访问jsp页面

《SpringBoot如何访问jsp页面》本文介绍了如何在SpringBoot项目中进行Web开发,包括创建项目、配置文件、添加依赖、控制层修改、测试效果以及在IDEA中进行配置的详细步骤... 目录SpringBoot如何访问JSP页python面简介实现步骤1. 首先创建的项目一定要是web项目2. 在

Linux限制ip访问的解决方案

《Linux限制ip访问的解决方案》为了修复安全扫描中发现的漏洞,我们需要对某些服务设置访问限制,具体来说,就是要确保只有指定的内部IP地址能够访问这些服务,所以本文给大家介绍了Linux限制ip访问... 目录背景:解决方案:使用Firewalld防火墙规则验证方法深度了解防火墙逻辑应用场景与扩展背景:

Python使用pysmb库访问Windows共享文件夹的详细教程

《Python使用pysmb库访问Windows共享文件夹的详细教程》本教程旨在帮助您使用pysmb库,通过SMB(ServerMessageBlock)协议,轻松连接到Windows共享文件夹,并列... 目录前置条件步骤一:导入必要的模块步骤二:配置连接参数步骤三:实例化SMB连接对象并尝试连接步骤四:

Linux 网络编程 --- 应用层

一、自定义协议和序列化反序列化 代码: 序列化反序列化实现网络版本计算器 二、HTTP协议 1、谈两个简单的预备知识 https://www.baidu.com/ --- 域名 --- 域名解析 --- IP地址 http的端口号为80端口,https的端口号为443 url为统一资源定位符。CSDNhttps://mp.csdn.net/mp_blog/creation/editor

安卓链接正常显示,ios#符被转义%23导致链接访问404

原因分析: url中含有特殊字符 中文未编码 都有可能导致URL转换失败,所以需要对url编码处理  如下: guard let allowUrl = webUrl.addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else {return} 后面发现当url中有#号时,会被误伤转义为%23,导致链接无法访问

ASIO网络调试助手之一:简介

多年前,写过几篇《Boost.Asio C++网络编程》的学习文章,一直没机会实践。最近项目中用到了Asio,于是抽空写了个网络调试助手。 开发环境: Win10 Qt5.12.6 + Asio(standalone) + spdlog 支持协议: UDP + TCP Client + TCP Server 独立的Asio(http://www.think-async.com)只包含了头文件,不依

poj 3181 网络流,建图。

题意: 农夫约翰为他的牛准备了F种食物和D种饮料。 每头牛都有各自喜欢的食物和饮料,而每种食物和饮料都只能分配给一头牛。 问最多能有多少头牛可以同时得到喜欢的食物和饮料。 解析: 由于要同时得到喜欢的食物和饮料,所以网络流建图的时候要把牛拆点了。 如下建图: s -> 食物 -> 牛1 -> 牛2 -> 饮料 -> t 所以分配一下点: s  =  0, 牛1= 1~

poj 3068 有流量限制的最小费用网络流

题意: m条有向边连接了n个仓库,每条边都有一定费用。 将两种危险品从0运到n-1,除了起点和终点外,危险品不能放在一起,也不能走相同的路径。 求最小的费用是多少。 解析: 抽象出一个源点s一个汇点t,源点与0相连,费用为0,容量为2。 汇点与n - 1相连,费用为0,容量为2。 每条边之间也相连,费用为每条边的费用,容量为1。 建图完毕之后,求一条流量为2的最小费用流就行了