盘点使 macOS 应用流量通过代理的多种方式

您所在的位置:网站首页 如何让macos的终端走代理程序 盘点使 macOS 应用流量通过代理的多种方式

盘点使 macOS 应用流量通过代理的多种方式

2023-11-17 14:13| 来源: 网络整理| 查看: 265

在开发过程中,我们经常需要使用到国外的资源,例如各种包依赖等。国内目前比较普遍的做法是使用由知名第三方维护的国内镜像。虽然方便,但也存在一些无法避免的问题,例如:

镜像可靠性未知,出问题时我们无能为力,只能等待第三方修复。镜像同步时间未知,可能存在数据滞后。存在安全隐患(尽管可能性较小)。

因此,我个人更加推荐依赖代理来实现快速访问所需资源的目的。本文不会涉及任何违反法律法规的内容,只来谈谈 macOS 下如何让不同应用的流量通过 本地的 代理服务。

在开始前,我将假设你已经在本地配置好了 HTTP 和 SOCKS5 代理服务,分别能够通过 http://127.0.0.1:8080 和 socks5://127.0.0.1:1080 访问。

系统代理

作为 macOS 内置的功能,你可以在 System Preferences -> Network -> Advanced -> Proxies 内配置系统代理。

盘点使 macOS 应用流量通过代理的多种方式

另外也可以使用命令行配置系统代理:

networksetup -setwebproxy "Wi-Fi" 127.0.0.1 8080 # HTTP proxy networksetup -setsocksfirewallproxy "Wi-Fi" 127.0.0.1 1080 # SOCKS5 proxy networksetup -setwebproxystate "Wi-Fi" on networksetup -setsocksfirewallproxystate "Wi-Fi" on

其中 "Wi-Fi" 是你的网络接口名,请根据实际情况填写。

不过,macOS 的系统代理仅对部分 GUI 或做了 macOS 适配的应用生效,例如 Chrome 等 Web 浏览器、系统更新等。在开发时我们经常需要接触 CLI,应该怎么做呢?

http_proxy 和 all_proxy 环境变量

绝大多数使用 HTTP 协议的 CLI 应用都支持这两个环境变量,这几乎已经成为了「行业标准」:

export http_proxy=http://127.0.0.1:8080 https_proxy=$http_proxy all_proxy=socks5://127.0.0.1:1080

典型支持的命令包括 curl、go get、composer install 等。使用 curl -v ipinfo.io 查看输出可发现代理配置已经生效:

* Uses proxy env variable http_proxy == 'http://127.0.0.1:8080' * Trying 127.0.0.1... ...

如果你本地的代理服务常驻后台运行,可将 export ... 命令写入 .zshrc,这样每次启动 Zsh(Shell)时就自动配置好了。

SSH Config ProxyCommand 指令

像 Git over SSH、SCP、SFTP 这类基于 SSH 协议的应用,并不支持以上两个环境变量。不过我们可以修改 SSH 配置文件 ~/.ssh/config 来实现,例如:

Host github.com ProxyCommand /usr/bin/nc -x 127.0.0.1:1080 %h %p

以上配置中的 ProxyCommand 只在连接到 github.com 时生效,你可以将 Host github.com 替换成其它 Git 服务商的主机名,也可以替换为 Host *,表示 SSH 到任意主机均生效。但我并不推荐这么做,除非你想 SSH 到自己的服务器时也通过代理。

Proxifier 和 Surge

根据我自己的经验,以上方法已经能够覆盖绝大多数开发者的使用场景。如果有些应用还是不走代理,你可以试试 Proxifier 和 Surge 这两款产品。其中 Surge 是 macOS 专有应用,不可用于 Windows 或 Linux 系统。这类应用的思路大致是:

伪装成 TUN 设备(可理解为虚拟网卡)。修改或覆盖系统默认路由,把所有 TCP、UDP、ICMP 等三层及以上的流量全部发到虚拟 TUN 设备。经过内部处理后把流量导向代理服务。代理服务器流出的流量使用 SO_MARK 等方式进行特殊标记,使用系统策略路由导向到真实网卡,避免死循环。

例如启动 Surge 增强模式后,可使用 netstat -nr 看出路由表的变化:

Routing tables Internet: Destination Gateway Flags Netif Expire default 192.168.1.254 UGSc en0 通过 ptrace 跟踪系统调用

与上一种方法类似,该方法的思路也是对 connect()「做手脚」,只是不通过劫持共享库实现。只可惜目前 macOS 上由于系统安全性等原因,这类实现仍然处在探索阶段。另外,我个人比较担心(猜测)通过 ptrace 监视系统调用,性能是否会受到明显影响。因此目前暂时不推荐。如果你有兴趣的话,可以看看 graftcp 项目。

总结

以上是我知道的几乎所有在 macOS 上配置代理的方法。个人比较推荐前几种,既能够覆盖大多数场景,也不需要安装额外的应用。如果你对网络方面感兴趣,也不妨探索性地尝试下其它方案。

macos proxy surge 本作品采用《CC 协议》,转载必须注明作者和本文链接 Former WinForm and PHP engineer. Now prefer Golang and Rust, and mainly working on DevSecOps and Kubernetes.


【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3