WSL2Linux 子系统(十一)

news2024/9/30 13:30:36

WSL 网络改为桥接模式(默认NAT)

上一篇文章 《WSL2Linux 子系统(十)》 详细讲述 WSL(Windows Subsystem for Linux)WSL 显示画面的几种方法。本篇讲述 WSL 网络转为桥接模式的两种方法。

桥接模式允许 WSL 实例获得一个与宿主机在同一子网中的 IP 地址,这样可以更方便地进行网络通信和服务发现。虽然桥接模式提供了更直接的网络访问,但也需要注意网络安全,因为 WSL 实例将暴露于网络中,需确保防火墙和安全策略的合理配置。

作者:炭烤毛蛋 ,点击博主了解更多。


提示:在桥接模式下,WSL 实例可以直接访问与宿主机相同的网络。

文章目录

  • WSL 网络改为桥接模式(默认NAT)
  • 1. Windows Hyper 虚拟机配置
  • 2. WSL 网络桥接配置
    • 2.1 动态方式连接桥接网络
    • 2.2 静态方式连接桥接网络
  • 结语


1. Windows Hyper 虚拟机配置

由于WSL2底层使用的是Hyper-V虚拟机,所以我们可以修改虚拟交换机的类型,来启用桥接网络。
Hyper-V管理器 -> 操作 -> 虚拟交换机管理器, 修改WSL的连接类型为“外部网络”(选择网络时需要勾选 为管理操作系统启用虚拟 LAN 表示)
LAN

WSL 桥接前需要将网卡改为内部桥接。

  • 列出所有网卡
get-netadapter

get-netadapter
外部网卡为 vEthernet (WSLBridge) ,等会会用到该网卡名。

  • 列出外部网卡
Get-VMSwitch -SwitchType External

Name SwitchType NetAdapterInterfaceDescription
---- ---------- ------------------------------
WSL_Hyper-Ⅵ External Intel(R) Wi-Fi 6 AX201 160MHz

Get-VMSwitch

  • 桥接网络,后面写的是网卡名称
Set-VMSwitch WSL -NetAdapterName WLAN
# 按照网络名称设置桥接网络
Set-WMSwitch WSL -NetAdapterName "Intel(R) WiFi 6 AX201 160MHz"
  • 断开桥接网络
Set-VMSwitch WSL -SwitchType Internal

DHCP 方式连接桥接网络
开启 DHCP 动态连接网络,网络连接成功后自动分配IP。

2. WSL 网络桥接配置

  • 配置 WSL 在 windows 的 .wslconfig
    win + R 输入 %USERPROFILE%/.wslconfig,选择记事本打开该文件。输入如下内容:
[wsl2]
networkingMode=bridged
vmSwitch=WSLBridge
ipv6=true
dhcp=true

重启 wsl 子系统生效配置。

2.1 动态方式连接桥接网络

  • 配置 WSL 中 wsl.conf
    进入wsl的Ubuntu子系统,打开/etc/wsl.conf,如果不存在该文件就创建它。
vi /etc/wsl.conf

需要写入内容

[boot]
systemd = true
[network]
generateHosts = true
generateResolvConf = true

重启 WSL 生效 networkd 生效配置。

systectl restart systemd-networkd

2.2 静态方式连接桥接网络

STATIC 静态连接网络,需要避免网络 IP 重复

  • WSL 在 windows 的 .wslconfig
    win + R 输入 %USERPROFILE%/.wslconfig,选择记事本打开该文件。输入如下内容:
[wsl2]
networkingMode=bridged
vmSwitch=WSLBridge
ipv6=true
dhcp=false

重启 wsl 子系统生效配置。

  • 配置 WSL 中 wsl.conf
    进入wsl的Ubuntu子系统,打开/etc/wsl.conf,如果不存在该文件就创建它。
vi /etc/wsl.conf
# 需要写入内容
[boot]
systemd = true
[network]
generateHosts = false
generateResolvConf = false
  • 配置 wsl-network.conf 和 resolv.conf
    修改网络配置 /etc/systemd/network/static-network.conf,如果没有该文件需要自行创建。
vi /etc/systemd/network/static-network.conf
# 填入以下配置内容
[Match]
Name=et*
#Name=en*
[Network]
DHCP=ipv4

修改 DNS 解析配置

vi /etc/resolv.conf
nameserver 192.168.31.2

重启 networkd 生效配置。

systectl restart systemd-networkd
  • 配置网络设置
    配置文件/etc/netplan/00-wsl2.yaml,如果不存在就创建它。
vi /etc/netplan/00-wsl2.yaml
# 写入以下格式的配置内容
network:
version: 2
renderer: networkd
ethernets:
eth0:
dhcp4: no
addresses: [192.168.31.15/24]
routes:
- to: default
via: 192.168.31.2
nameservers:
addresses: [192.168.31.2]

应用新的网络设置重启 WSL2 子系统生效配置。

netplan apply

重启wsl子系统的IP地址将不再随机变化,且直接桥接到外部局域网。

结语

不枉博主详细讲解,欢迎订阅博主–炭烤毛蛋 。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2179736.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【包教包会】CocosCreator3.x框架——音频声音模块(无需导入、无需常驻节点)

下载地址:AudioDemo3.x: CocosCreator3.x框架——音频模块 注意事项: 1、gi.musicPlay、gi.soundPlay是同步函数,使用前必须先将音频加载到缓存 Demo通过SceneLoading实现了一个极简的Loading页面,将音频全部加载后进入游戏&…

JAVA智慧社区系统跑腿家政本地生活商城系统小程序源码

智慧社区系统集成跑腿家政与本地生活商城 —— 打造便捷高效的社区生活圈 🏠 智慧社区新时代:一站式服务新体验 在快节奏的都市生活中,智慧社区系统正悄然改变着我们的生活方式。它不再只是一个居住的空间,而是集成了跑腿家政、本…

AI换脸技术新纪元:直播与视频创作的新利器

在数字媒体时代,实时面部交换技术正变得越来越流行。它不仅为视频创作者提供了新的表达方式,也为直播行业带来了革命性的变化。以下是一些目前市场上领先的实时面部交换软件: 🌟 FaceFusion FaceFusion 是一款功能强大的实时面部…

2023ICPC区域赛杭州站

VP链接:Dashboard - The 2023 ICPC Asia Hangzhou Regional Contest (The 2nd Universal Cup. Stage 22: Hangzhou) - Codeforces D. Operator Precedence 一道构造题,将序列构造成 1 2 -1 2 -1 ...... 2 -1 x。根据题目条件,可以推出来 x …

全新带货思路,用AI美女数字人做情感赛道,27天销量1559单

本期就另外分享一个全新的AI美女数字人带货思路,如果你正好对AI视频带货感兴趣,那么本期内容直接给你抹平“视频号上AI美女数字人玩法信息差”,最主要还是趁这类内容还不卷的时候,赶紧行动起来! 更多实操教程和数字人工…

智能AI对话绘画二合一网站源码系统 带完整的安装代码包以及搭建部署教程

系统概述 智能AI对话绘画二合一网站源码系统是一款基于先进的人工智能技术开发的综合性网站源码系统。该系统将AI对话功能和AI绘画功能完美融合,用户可以通过简单的对话指令,让系统生成符合要求的绘画作品,或者通过对话了解绘画相关的知识和…

世优科技出席36氪2024具身智能大会圆桌对话,入选创新应用案例

具身智能,作为人工智能领域的前沿分支,聚焦于构建能够通过集成感知与交互机制,在物理环境中实现动态适应与实时互动的智能系统及机器人平台。 9月26日,由36氪主办的“2024具身智能大会”以“让AI通向物理世界”为主题,…

Unity NetCode 客户端连接不上服务器,局域网模式 Failed to connect to server.

报错代码: Failed to connect to server. 报错截图: 解决办法: 服务端:绑定127.0.0.1和端口 客户端:写好对应服务端ip和端口 如何查看服务端所在局域网IP,192.xxx.xxx.xx,就不用教了吧。 注意这个钩,得点下,默认不勾选。 意…

【MYSQL】mysql约束---自增长约束(auto_increment)

1、概念 在Mysql中,当主键为自增长后,这个主键的值就不再需要用户输入数据了,而由数据库系统根据定义自动赋值。每增加一条记录,主键会自动以相同的步长进行增长。 注意:自增长约束通常与主键放在一起使用。 通过给…

AutoGen框架进行多智能体协作—反思与提升博客文章质量(三)

1. 实践场景 两个代理之间通过互相反思以提升博客质量。其中一个代理作为修改意见提出者,另一个代理为写作者。写作者依据要求进行内容创作,评论员则提出修改要求,作者再根据要求对内容进行重新调整。 2. 代码实践 本节学习内容&#xff1a…

一文上手SpringSecurity【八】

RBAC(Role-Based Access Control),基于角色的访问控制。通过用户关联角色,角色关联权限,来间接的为用户赋予权限。 一、RBAC介绍 RBAC(Role-Based Access Control),即基于角色的访…

Unity实战案例全解析:RTS游戏的框选和阵型功能(3)生成范围检测框 +重置框选操作

前篇:Unity实战案例全解析:RTS游戏的框选和阵型功能(2) 生成选择框-CSDN博客 本案例来源于unity唐老狮,有兴趣的小伙伴可以去泰克在线观看该课程 我只是对重要功能进行分析和做出笔记分享,并未无师自通&…

UR学习记录

实践 示教器使用 外设使用 抓手,力传感器 开关、气动元件、电磁阀 示教器编写一个完整的抓取放置应用代码 使用示教器变量编写一个相对运动的应用代码 UR坐标表示计算 UR TCP/IP通讯 理论基础 齐次变换 python 矩阵计算,代码示例 import numpy as np…

Gromacs位置限制问题

Atom index n in position_restraints out of bounds A common problem is placing position restraint files for multiple molecules out of order.(一个常见的问题是无序放置多个分子的位置约束文件。)Recall that a position restraint itp (page 449) file containing a …

TDengine 签约国家电投旗下四大火力发电厂,助力汽轮机振动数据的有效管理

在火力发电厂中,汽轮机作为能量转换的核心设备,其稳定性直接关系到电力供应的可靠性和经济效益。因此,对汽轮机状态的监测与维护成为了发电厂日常经营中的重要工作。然而,传统的监测方式受到复杂运行环境和数据处理能力的限制&…

KA客户关系管理策略全解析

在当今商业竞争日益激烈的环境中,如何有效管理和维护关键客户关系成为企业制胜的关键。无论是初创企业还是跨国公司,都面临着同样的挑战,那就是如何通过精准的客户关系管理策略,不仅保留现有客户,还能不断拓展新的商业…

【Git原理与使用】Git初识基本操作

Git初识&&基本操作 1.初识Git2.Git安装3.Git基本操作3.1创建Git本地仓库3.2配置Git3.3认识工作区、暂存区、版本库3.4添加文件3.5修改文件3.6版本回退3.7撤销修改3.8删除文件 点赞👍👍收藏🌟🌟关注💖&#x1f…

大数据-156 Apache Druid 案例实战 Scala Kafka 订单统计

点一下关注吧!!!非常感谢!!持续更新!!! 目前已经更新到了: Hadoop(已更完)HDFS(已更完)MapReduce(已更完&am…

Linux 学习笔记(二):深入理解用户管理、运行级别与命令行操作

Linux 学习笔记(二):深入理解用户管理、运行级别与命令行操作 前置学习内容:Linux学习(一) 1. 用户管理 1.1 用户密码管理 创建用户密码 使用 passwd 命令可以为指定用户设置密码: sudo pas…

AWS Network Firewall - IGW方式配置只应许白名单域名出入站

参考链接 https://repost.aws/zh-Hans/knowledge-center/network-firewall-configure-domain-ruleshttps://aws.amazon.com/cn/blogs/networking-and-content-delivery/deployment-models-for-aws-network-firewall/ 1. 创建防火墙 选择防火墙的归属子网(选择公有…