使用 Windows 虚拟机运行虚拟专用网客户端为 Linux 提供内网环境

本文最后更新于:2024年11月16日 凌晨

起因

最近在某家公司实习,公司内部的 git 部署在内网环境上,需要通过虚拟专用网的客户端(天翼云的 AONE)才能够正常访问。很可惜,客户端只提供了 Windows 和 MacOS 的版本。

工作的代码总是要提交的,我也不想改变我的开发环境,又不希望在 Windows 上使用 git-for-windows 这个近乎简陋的工具进行代码提交,更别说还有一些别的内网服务接下来可能也会用到。所以最好的办法就是在 Linux 下也配置好能够访问内网的环境。

理论

在 Windows 下使用 AONE 的网络拓扑是这样的

而我的方案则是使用 Windows 虚拟机开启 AONE,并在这台虚拟机上开一个 socks5 server 负责代理 Linux 宿主机需要打到内网服务的流量。网络拓扑如下

根据 bilibili 上技术蛋老师的视频总结,我们应该选择使用网卡桥接的网络配置,只有这个配置方式同时支持「宿主->虚拟机」和 「虚拟机->互联网」的网络。

图片来源: bilibili 技术蛋老师

实操

在 Windows 虚拟机中开启虚拟专用网客户端

开启 AONE,不做赘述

开启 socks server,监听地址为 0.0.0.0 (或者设置为宿主机的 IP 地址)

在「熊孩子(BearChild)」的推荐下,我这里采用的是大名鼎鼎的二级射线(某 V 字开头的常见软件),直接从 GIthub Release 中下载 Windows X64 的压缩包,简单配置下即可,如果没有什么特殊需求的话可以只修改图中的两处配置。

在终端中通过该软件的 run 命令即可开启服务

在宿主机进行测试

我这里使用的是 mzz2017 编写的 gg 命令进行代理,代理服务器的 ip 地址使用虚拟机下 ipconfig 命令获得的 ip 地址,端口号则对应上面配置文件中的 port 参数。

这里 curl 百度得到了正确的相应,说明通道是通的,gg 也可以用于代理浏览器。经实测能够正常访问公司内网服务,不便在博客中展示。


使用 Windows 虚拟机运行虚拟专用网客户端为 Linux 提供内网环境
https://zhul.in/2024/05/23/setup-network-environment-for-non-linux-vpn-client-with-virtual-machine/
作者
竹林里有冰
发布于
2024年5月23日
更新于
2024年11月16日
许可协议