WSL - 解决虚拟专用网络连接下无法访问网络的问题

在这里插入图片描述

本文详细介绍了当公司电脑连接VPN后,WSL中的Ubuntu实例无法访问外部网络的常见问题及其解决方案。通过修改WSL Ubuntu内部的/etc/wsl.conf文件,成功解决了网络连接和域名解析的难题,确保WSL Ubuntu在VPN环境下也能顺畅地访问外部资源。

当公司电脑连接到虚拟专用网络后,WSL的Ubuntu就无法访问外部网络。

1. 查看WSL版本

> wsl --version

WSL version: 2.6.1.0
Kernel version: 6.6.87.2-1
WSLg version: 1.0.66
MSRDC version: 1.2.6353
Direct3D version: 1.611.1-81528511
DXCore version: 10.0.26100.1-240331-1435.ge-release
Windows version: 10.0.26200.6584

2. 升级WSL

先关闭WSL再升级。

> wsl --shutdown
> wsl --upgrade

3. 创建WSL配置文件

在Windows系统下,创建C:\Users\USER_NAME\.wslconfig。内容如下:

[wsl2]
networkingMode=mirrored
dnsTunneling=true

再重新打开WSL的终端,看可否ping通外部网络。我可以ping通8.8.8.8,但是在sudo apt update的时候无法连接到镜像服务器。报错显示的无法解析镜像服务器的域名。

4. 查看Windows防火墙

以Admin身份打开Powershell。

PS C:\WINDOWS\system32> Get-NetFirewallHyperVVMSetting -PolicyStore ActiveStore -Name '{40E0AC32-46A5-438A-A0B2-2B479E8F2E90}'


Name                  : {40E0AC32-46A5-438A-A0B2-2B479E8F2E90}
Enabled               : True
DefaultInboundAction  : Block
DefaultOutboundAction : Allow
LoopbackEnabled       : True
AllowHostPolicyMerge  : True

如果DefaultOutboundAction的行为是Block的话就需要设置为Allow。我的是没有问题的。

Set-NetFirewallHyperVVMSetting -Name '{40E0AC32-46A5-438A-A0B2-2B479E8F2E90}' -DefaultOutboundAction Allow

5. 查看WSL内的WSL配置

将最后一项的generateResolvConf改成true。

> cat /etc/wsl.conf

[automount]
enabled = true
root = /mnt/
options = "metadata,umask=22,fmask=11"

[interop]
enabled = true
appendWindowsPath = true

[network]
generateResolvConf = false

关闭WSL并重新打开WSL的终端,网络就通了。

📚 延伸阅读

更多内容持续更新于我的博客:https://www.zenseek.site

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值