WSL2连接不了外网怎么办?

某天忽然WLAN变成地球图标,上不了Internet,搞了半天网络适配器,仍然不行。回忆之前做过的操作,曾经运行过ZoogVPN,试着启动并连接,然后退出,WLAN神奇地恢复了连接,可以上Internet了。
但WSL2仍然无法连接外网,导致提交不了git。问了chatgpt以及参考了多篇wsl网络异常的文章(附后),试了DNS重置、wsl重装,宿主机windows与wsl2之间已经能互相ping通,宿主机windows在命令终端能正常ping外网(如www.baidu.com),但wsl2里却仍然无法ping外网。
(补充:此时wsl2其实已经是能够ping外网了,只是要等待10多20秒就能看到响应信息,当时没有等待这么久就误以为wsl2仍然ping不通外网。后面的描述记录当时自己排查误入歧途的过程,大家可以不看)
宿主机windows在命令终端能正常ping外网

wsl2里却仍然无法ping外网

WSL2网络原理

wsl2 可以理解为宿主机完整虚拟出来的一个完整的 Linux 虚拟机,拥有自己的逻辑上独立的网卡,也即拥有属于自己的独立网络栈。
wsl2 与 宿主机的网络拓扑图
上图描述了两者在逻辑上的关系,从上图就可以看到 WSL2 要与外界进行通信,就必须保证 WSL2 能正常访问宿主机( 所以这里就存在宿主机的防火墙拦截问题 ),因为宿主机是其与外部进行通信的桥梁。要保证 WSL2 与宿主机的通信正常就要确认两者的IP地址是否在同一个网段, 其次 WSL2 的默认路由必须是宿主机在同一网段的地址(172.25.32.1/20)

排查并解决

根据wsl2的网络原理,在wsl2里执行ip route命令,可以看到宿主机的虚拟网卡ip:172.17.240.1,wsl2的虚拟网卡ip:172.17.253.160,两者不在同一个网段。
(补充:两者其实是在同一个网段的)
在这里插入图片描述
下图可以看出wsl2(左侧)的虚拟网卡ip:172.17.253.160,子网掩码255.255.240.0,宿主机(右侧)的虚拟网卡ip:172.17.240.1,子网掩码255.255.240.0
在这里插入图片描述

知道了原因,那就把wsl2的ip修改为与宿主机的ip同一网段好了。

$ sudo ifconfig eth0 172.17.240.100 netmask 255.255.240.0 

在这里插入图片描述
退出wsl2再进入,ping www.biadu.com就通了。但从公司回到家中,又不通,原来上面这条修改ip地址的命令语句不具有持久作用的。

最后,动手计算了ip:172.17.253.160 netmask:255.255.240.0 与 ip:172.17.240.1 netmask:255.255.240.0这两者的ip地址其实是同一网段。在wsl2中ping www.baidu.com后耐心等待10来20秒左右,终于看到ping通了。
在这里插入图片描述
这次排查故障是浪费了不少时间,但从中也了解了宿主机与wsl2之间的网络原理,特此记录下来。

参考:
WSL2 网络异常排查 [ping 不通、网络地址异常、缺少默认路由、被宿主机防火墙拦截]

2023-8-29后记:
今天才知道wsl2连接不上外网的真正的原因,是家里的华为路由器http诊断异常,将华为路由器reset后,wsl2就可以ping通了。
注:在公司的网络wsl2是能正常连接上外网的。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值