起因#

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

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

理论#

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

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

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

图片来源: 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 也可以用于代理浏览器。经实测能够正常访问公司内网服务,不便在博客中展示。