WSL(ubuntu) 和Cisco Anyconnect存在的网络连接异常问题

编程知识 更新时间:2023-04-20 10:07:00

有时,脚本执行对环境有要求,比如需在linux、MACOS环境下执行,windows不支持。

由于我本机是windows,所以安装了ubuntu。在此插一句,做开发最好还是mac机,不然会很痛苦。在本机微软商店下载ubuntu,可正常使用。但连接了公司vpn(Cisco Anyconnect)后,就连不上网。导致脚本执行中断,比如镜像上传,go build等需要连网的操作。

ping baidu没反应。

经过长久查询,具体原因如下:

Anyconnect在链接后会根据vpn服务器的配置下发路由策略和dns策略,在本地存在wsl或者docker容器的情况下,因虚拟网络策略与vpn策略冲突导致网络异常,主要由两点引起:

         1、路由优先级问题。新创建的端口metric小于veth网卡,造成路由错误。
         2、dns解析问题。未连接vpn情况下是通过本地网关递归解析,vpn连接后造成本地递归失效(按说不应该失效,怀疑有其他坑待查),走vpn分配的dns服务器做解析即可。

解决:

        1、调整接口metric值

              Cisco anyconnect 连接的前提下,关闭WSL,管理员权限打开PowerShell(PowerShell ISE),执行:

Get-NetAdapter | Where-Object {$_.InterfaceDescription -Match "Cisco AnyConnect"} | Set-NetIPInterface -InterfaceMetric 6000

              完成后,可在WSL中ping 114.114.114.114,正常情况下已通。             

         2、设置WSL里的路由

              a、首先获得vpn分配的dns服务器地址,在管理员权限的PowerShell中执行:

(Get-NetAdapter | Where-Object InterfaceDescription -like "Cisco AnyConnect*" | Get-DnsClientServerAddress).ServerAddresses

              获得:10.10.0.124

                          10.10.0.132

             b、更新wsl里的域名配置文件,vim /etc/resolv.conf,添加上述两个ip保存即可。

             cat /etc/resolv.conf
                 nameserver 10.10.0.124
                 nameserver 10.10.0.132

ping baidu即可正常。

我遇到的问题:本地各种尝试各种百度打不开PowerShell,要么显示由于计算机限制被取消要么就是系统管理员已阻止这个应用。PowerShell ISE也打不开。经过一番查找之后使用如下方式解决: 桌面新建一个.reg文件,内容如下:

Windows Registry Editor Version 5.00

[-HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows\CurrentVersion\policies]
[-HKEY_CURRENT_USER\SOFTWARE\Microsoft\Windows\CurrentVersion\policies]

保存后点击,PowerShell ISE就可以以管理员权限执行了,在PowerShell ISE上执行命令即可。

更多推荐

WSL(ubuntu) 和Cisco Anyconnect存在的网络连接异常问题

本文发布于:2023-04-15 21:52:00,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/980628a78fb8c93fd5d0e62cbf3a89f7.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:异常   网络   ubuntu   WSL   Anyconnect

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!

  • 79182文章数
  • 17阅读数
  • 0评论数