connected 状态不要当作「已经能打开网页」的证明。Clash Verge Rev 官方文档把 System Proxy 和 TUN 分成两类入口:前者主要改操作系统代理设置,通常覆盖浏览器;后者安装虚拟网卡,用来接管不跟随系统代理的程序。入口选错,节点再亮也没用。
这篇只处理一种现象:客户端看起来已连接,节点测试有延迟,网页却打不开、转圈、部分域名失败或只有某个浏览器失败。客户端无法启动、订阅地址返回空内容、配置文件无法导入,不在这篇里展开。
##判断请求有没有进客户端?
打开日志后刷新目标网页,不要只看首页状态灯。日志里有没有新记录,是整篇排查的分叉点。
| 访问网页时的信号 | 更可能卡住的位置 | 做什么 |
|---|---|---|
| 日志没有任何新记录 | 系统代理、TUN、浏览器代理扩展 | 查入口是否接管请求 |
| 日志出现域名但 DNS 超时 | DNS、DoH、Private DNS、fake-ip 映射 | 查 DNS 策略和浏览器 DNS |
日志显示 DIRECT 或 REJECT | 规则顺序、规则集、final | 查规则命中 |
| 日志显示 IPv6 地址后失败 | IPv6 出口或系统优先级 | 做 IPv4-only 对照 |
| 日志显示 timeout / reset / TLS 错误 | 节点出口、协议字段、目标握手 | 换同组节点验证 |
如果日志完全没有记录,先别换节点。你的浏览器请求可能根本没经过客户端。
系统代理开了,为什么浏览器还是打不开?
系统代理模式只接管愿意读取操作系统代理设置的程序。Clash Verge Rev 快速入门也把它描述为通过开关修改系统代理,主要满足大多数浏览器流量;游戏、命令行、部分商店客户端不一定走这条路。
桌面端先查 4 件事:
- 系统代理地址是否指向
127.0.0.1或localhost的客户端端口。 - 浏览器有没有独立代理扩展,例如 SwitchyOmega、Proxy SwitchySharp 或企业安全插件。
- 浏览器是否使用独立配置文件,新配置文件可能没有继承系统代理。
- 客户端退出后系统代理是否残留,残留端口会导致浏览器一直连本机空端口。
Windows 上可以用系统设置里的「代理」页面确认地址和端口。macOS 上要看当前网络服务的代理配置,切换 Wi-Fi 后也可能出现代理状态变化。
TUN 打开后全断,查哪几个开关?
TUN 是虚拟网卡入口,排查顺序和系统代理不同。Mihomo 文档里常见字段包括 enable、stack、auto-route、auto-detect-interface、dns-hijack、strict-route 和路由排除;sing-box TUN 文档在 1.14.0 之后还增加了 dns_mode、dns_address 等 DNS 接管相关字段。
| TUN 配置点 | 正常目标 | 异常表现 | 处理方式 |
|---|---|---|---|
| 虚拟网卡 | 系统出现 TUN 网卡并有路由 | 开关亮但无网卡 | 重启客户端或检查权限 |
auto-route | 默认流量进入 TUN | 开 TUN 后全断 | 先关闭再单独启用,排除路由冲突 |
auto-detect-interface | 出口网卡选对 | 多网卡、VPN、热点下循环 | 手动指定出口或关闭冲突网络 |
dns-hijack / dns_mode | DNS 进入内置 DNS | 域名不解析或被外部 DNS 接管 | 查端口 53、Private DNS、浏览器 DoH |
strict-route | 减少非预期出口 | 某些本地网段或软件断开 | 临时关闭对照,再加排除网段 |
| route exclude | NAS、打印机、网关仍可访问 | 局域网设备打不开 | 排除局域网网段 |
sing-box route 文档明确提到,TUN 下可用 auto_detect_interface 避免路由环路;如果已经给 outbound 绑定了接口,这个自动检测不会再生效。多网卡电脑、公司 VPN、手机热点共享网络最容易踩这个坑。
DNS 有问题时,日志通常长什么样?
DNS 故障最常见的表现是:访问 IP 能通,访问域名不通;同一个网站主域名能开,登录、图片、API 子域名打不开;或浏览器报 DNS 相关错误但客户端显示 connected。
Mihomo DNS 文档里,enhanced-mode: fake-ip 会给域名分配 fake 地址,再由客户端映射回真实域名;nameserver-policy 可以让特定域名或 geosite 走指定解析器;fallback 和 fallback-filter 会影响备用解析结果。sing-box 则把 DNS 与 route 分开配置,TUN 的 DNS 接管还受 dns_mode 和路由动作影响。
排查时按这个顺序:
- 访问网页,日志里先找目标域名,不要只看浏览器错误页。
- 如果出现
NXDOMAIN、lookup failed、context deadline exceeded,查 DNS。 - 如果使用 fake-ip,确认客户端没有丢失 fake IP 到域名的映射。
- 关闭浏览器 DoH 做一次对照。Chrome、Edge、Firefox 都可能绕过系统 DNS。
- Android 设备检查 Private DNS;开启后会影响部分 DNS 劫持场景。
- 路由器、公司安全软件、杀毒软件也可能把 DNS 改到固定地址。
刚换订阅、多端迁移或同一份配置在不同客户端表现不一致时,可以用兼容 Clash / Singbox / V2Ray 的订阅做对照。对照时只改订阅,不同时改 DNS、规则和客户端版本,否则看不出真正变量。
规则模式命中错了,怎么快速确认?
规则问题比 DNS 更隐蔽。网页打不开时,日志里如果显示目标域名命中 DIRECT、REJECT、错误策略组或未预期的 final,connected 状态不会告诉你这件事。
Mihomo 的规则文档和 sing-box route 文档都强调规则列表、规则集和默认出站的顺序。sing-box 的 final 为空时会使用第一个 outbound;Mihomo 配置里常见的 MATCH、FINAL 或兜底规则也会影响所有未匹配请求。
检查规则时不要只搜主域名。例如网页地址是 example.com,实际失败的可能是:
| 页面现象 | 可能失败的域名类型 | 日志里重点看什么 |
|---|---|---|
| 首页能开,登录失败 | api.、accounts.、oauth. | 是否命中同一策略组 |
| 图片和脚本加载不出 | cdn.、static.、对象存储域名 | 是否被广告或隐私规则拦截 |
| 下载按钮无响应 | Release、对象存储、跳转域名 | 是否走了错误 final |
| 公司后台只转圈 | SSO、验证码、风控域名 | 是否部分 DIRECT、部分代理 |
改规则后要重载配置,再刷新网页。只保存文件、不重载内核,日志不会变化。
IPv6 为什么会让 connected 变得误导?
很多系统会优先尝试 IPv6。节点测试走 IPv4 成功,浏览器访问目标域名时却优先拿到 AAAA 记录,就会出现「客户端 connected,但网页一直转圈」。
三个对照最快:
- 在客户端或系统里临时关闭 IPv6,只保留 IPv4 测一次目标网站。
- 看日志里失败的是 IPv4 地址还是 IPv6 地址。
- 如果只有 IPv6 失败,检查 DNS 策略是否返回 AAAA、规则是否覆盖 IPv6、出口是否支持 IPv6。
不要长期靠关闭 IPv6 当最终方案。更稳妥的做法是让 DNS、规则和出口能力一致:要么完整支持 IPv6,要么明确让相关域名按 IPv4 访问。
浏览器缓存和 DoH 什么时候要管?
同一台电脑里,App 能访问、只有一个浏览器不行,优先怀疑浏览器层。浏览器会缓存 DNS、HSTS、证书状态、Service Worker 和站点数据;代理扩展也可能覆盖系统代理。
最省时间的验证组合:
- 用隐身窗口打开目标网页。
- 换一个没有代理扩展的浏览器。
- 关闭浏览器安全 DNS / DoH。
- 清理目标站点数据,而不是清空所有历史记录。
- 如果只某个域名失败,清系统 DNS 缓存后再测。
如果换浏览器立刻正常,别继续动 TUN 和规则,处理扩展、DoH、站点数据和证书缓存。
怎么判断已经修好
修好不是首页打开一次就算。至少做 5 个验证动作:
| 验证动作 | 合格信号 | 不合格信号 |
|---|---|---|
| 刷新目标网页 | 日志出现目标域名 | 日志仍无记录 |
| 打开登录或搜索页 | API、静态资源都有记录 | 只有主域名成功 |
| 切换浏览器 | 结果一致 | 只有某浏览器失败 |
| 重启客户端 | 仍能访问 | 依赖临时切换才可用 |
| 断开再连网络 | 系统代理 / TUN 状态恢复 | 代理端口残留或 TUN 丢路由 |
最后再看节点。DNS、规则、系统代理、TUN、IPv6、浏览器都排除后,同一策略组内换 2 个节点,如果错误从 timeout 变成成功,才说明出口层是主要变量。
这篇不处理什么?
这篇不处理订阅地址 403、404、过期、返回登录页,也不处理 YAML、JSON 解析失败。那些问题发生在配置导入阶段,和 connected 后网页打不开不是同一层。
也不把所有故障归因到线路质量。代理客户端排错最怕一上来就换订阅、换客户端、重装系统;日志里没有目标域名时,换多少节点都不会解决系统代理或 TUN 接管问题。