用户诉求 精选 标签: Clash Telegram MTProto 分流规则

Telegram 连线卡住?Clash 分流域名与 MTProto 排查步骤

桌面端 Telegram 长时间停在「连线中」、会话列表不刷新、图片与语音发不出去,很多人第一反应是「节点挂了」。实际上更常见的是:Clash 的分流没有把 Telegram 相关域名和 MTProto 出口对齐,DNS 解析走了国内或被 fake-ip 干扰,或规则顺序让流量误落到了 DIRECT。本文按「先确认代理是否接管 → 再补域名规则 → 再看连接日志里的主机名与端口 → 最后微调 DNS 与模式」的顺序,帮你系统排查,也提醒与依赖 进程分流 + UDP 的游戏语音类场景之差异。

约 18 分钟阅读
Clash 编辑部

一、桌面端「连线中」常见表现

在 Windows 或 macOS 上使用官方 Telegram 桌面客户端时,若网络或代理链路异常,界面往往会长时间停留在「正在连线」或顶部旋转的连接指示,聊天记录不同步、无法搜索公开频道、媒体Thumbnail 空白。这类问题与「网页能开、唯独 TG 不行」常常同时出现:说明全局上网可能正常,但 Telegram 所依赖的特定主机名MTProto 长连接没有被正确送到可用节点。

另一类容易被误判的情况是:系统或浏览器已经走代理,但 Telegram 默认使用自带的连接方式,未必读取系统 HTTP 代理。若你只开启了「系统代理」而未启用 TUN / 混合端口接管整台机器,或规则里把 Telegram 相关流量标成直连,桌面客户端仍可能去连被干扰的路线,从而表现为无限重连。

二、先确认 Clash 是否接管 Telegram

在改 YAML 之前,建议用三件事快速分层: 暂时关闭 Clash,用手机热点或另一网络试 TG 能否秒连——若仍不行,优先怀疑账号、客户端版本或本地防火墙。 打开 Clash 的连接 / 日志面板,启动 Telegram,看是否有发往 *.telegram.orgt.me 或数据中心 IP 的条目,以及策略是 DIRECT 还是你的代理策略组。 若日志里几乎没有 Telegram 相关连接,多半是 DNS 阶段失败、或应用走了未被接管的路径(例如未开 TUN 且未设系统代理)。

建议:排查时固定一个已知可用的节点,避免同时调整「规则、DNS、节点」三个变量;确认链路通了再恢复自动选择或 url-test。

若你使用 Mihomo / Clash Meta 系列内核,可在日志里关注 TLS 握手、dial 超时或 context deadline exceeded 等关键字——它们常与节点被阻断SNI 识别异常有关,而不一定是「少写了一条域名」。

三、Telegram 域名与 Clash 分流示例

Telegram 客户端会与多个域名通信:官方网站与更新、网页版入口、API 与中继等。桌面端常见主机名包括 telegram.orgdesktop.telegram.orgcore.telegram.org、短链 t.me、网页版使用的 web.telegram.org 等。实际连接日志里还可能出现带地区或负载均衡含义的子域,因此以连接日志为准增补规则,比死记硬背列表更可靠。

Clash 中可为 Telegram 单独建策略组(例如 Telegram-Group),把相关域名放在靠前的规则位置,避免被 GEOIP,CN,DIRECT 或「国内域名直连」类规则提前抢走:

# Example: send Telegram-related domains to a dedicated group
proxy-groups:
  - name: "Telegram-Group"
    type: select
    proxies:
      - "PROXY"
      - "HK-Node"
      - "JP-Node"
      - "DIRECT"

rules:
  - DOMAIN-SUFFIX,telegram.org,Telegram-Group
  - DOMAIN-SUFFIX,t.me,Telegram-Group
  - DOMAIN-SUFFIX,tdesktop.com,Telegram-Group
  - DOMAIN-SUFFIX,telesco.pe,Telegram-Group
  - DOMAIN-SUFFIX,legra.ph,Telegram-Group
  - DOMAIN-SUFFIX,comments.app,Telegram-Group
  - DOMAIN-KEYWORD,telegram,Telegram-Group
  - GEOIP,CN,DIRECT
  - MATCH,PROXY

DOMAIN-KEYWORD,telegram 命中面较宽,若与你内网或测试环境冲突可删去,改用在日志里看到的精确子域。规则语法以你所用内核文档为准;若订阅会覆盖本地规则,需用 rule-providersbehavior: classical 或调整合并顺序,避免「加了的规则永远不生效」。

四、MTProto、端口与连接日志

MTProto 是 Telegram 自有协议。桌面客户端与服务端之间多为 TCP 长连接,常见对外端口包含 443805222 等(依数据中心与配置而异)。若在 Clash 里只对「浏览器常用的 HTTPS」做了代理,而 Telegram 解析到的目标 IP 落在策略为直连的段上,就会出现「一直转圈」。

排查时请在日志中查看:目标地址是域名还是纯 IP端口、以及最终策略组。若域名已命中 Telegram 组,但仍握手失败,可换节点、换线路或检查本机防火墙是否拦截了 Clash 的出站。语音通话等场景还会用到 UDP,但大多数「卡在登录/同步」仍以 TCP 路径为主;若你同时语音异常,可再对照站内 Discord Windows 进程分流与 UDP 一文,理解 UDP 与 TUN 的关系。

注意:部分网络会对长连接限速或间歇断流。若仅 TG 卡顿而网页流畅,可尝试更换数据中心地区节点,或让运营商线路与节点所在 region 更匹配。

五、DNS、fake-ip 与规则顺序

DNS 导致 Telegram 瘫痪的情况非常常见:解析被污染、返回错误 IP、或走了国内 DoH/DoT 却仍想访问境外中继。请确认 Clash 的 DNS 配置与 nameserver / fallback 逻辑是否合理,以及是否对 Telegram 相关域使用了正确的解析路径。

开启 fake-ip 时,若未在 fake-ip-filter 中放行 Telegram 所需域名,可能导致应用拿到本地虚拟地址后行为异常。可按 fake-ip 与 DNS 排查 一文逐步核对,必要时对关键域使用真实 IP 解析。无论是否 fake-ip,都请保证「Telegram 相关规则」排在过早的「全量直连」规则之前,否则策略组根本不会参与决策。

六、规则模式、系统代理与 TUN

规则模式下,只有被规则指向代理的流量会走节点;若 Telegram 未命中任何 PROXY 规则,就会直连,容易撞墙。可临时切到 全局验证:若全局正常而规则模式不行,几乎可以断定rules 缺项或顺序有误。

在 macOS / Windows 上,若仅依赖「系统代理」,部分原生程序未必遵循;TUN 模式或厂商提供的「虚拟网卡接管」通常对桌面 Telegram 更友好。开启 TUN 后若仍异常,需检查是否与公司 VPN、其他过滤驱动冲突,或路由表未包含 Telegram 所用目标段。

做完以上调整后,建议重启 Telegram 客户端并让 Clash 重新加载配置,避免旧连接与会话缓存干扰判断。

七、与 Discord / Steam 类场景的差别

站内 Steam 下载与联机、Discord 等场景,往往强调 进程名分流UDP 以及 Windows 防火墙放行。Telegram 桌面端以域名 + MTProto TCP 为主,一般不需要绑定 Telegram.exe 进程规则即可完成登录与同步;若你只抄了游戏类教程而未补域名,反而会困惑「为什么 Steam 好了 TG 仍挂」。当然,若你在同一台电脑上同时硬挂语音与游戏,仍要保证 TUN/UDP 与策略组互不打架。

对比项 Telegram 桌面端 Discord / Steam 等
分流主要依据 域名、关键词、连接日志精补 常配合进程规则与 UDP 路径
协议侧重 MTProto over TCP 为主 游戏与语音更重 UDP、NAT
典型遗漏 子域未覆盖、规则被直连抢先 TUN 未开、防火墙拦 UDP
首要排查 DNS、fake-ip-filter、规则顺序 进程是否走代理、端口放行

八、排障对照表

现象 建议优先检查
永远「连线中」、无错误码 连接日志是否无 Telegram 记录(未接管);是否需 TUN;DNS 是否解析异常
日志显示 DIRECT 却访问失败 把相关域名移到 GEOIP,CN 之前;检查订阅覆盖顺序
换节点立即好 原节点 IP 被干扰或限速;固定低延迟地区试用
仅网页版能登、客户端不行 浏览器走代理而客户端未走;核对系统代理 / TUN
开 fake-ip 后立刻异常 fake-ip-filter 或调整 DNS;参考专文逐项验证

九、小结

Telegram 桌面客户端卡在「连线中」,多数是路径没有接到可用节点,而不是客户端本身「坏了」。把 Clash分流规则写到能覆盖实际访问的主机名、把 MTProto 相关 TCP 连接从日志里对齐策略组,再处理 DNSfake-ip 的边角,就能解决大部分久拖不决的同步问题。相比「全局暴力代理」,为 Telegram 单独建组、在规则前排声明域名,既方便切换地区节点,也避免影响国内业务流量。

若你希望在同一套客户端里同时稳住即时通讯、游戏与开发工具,除了本文外,可继续阅读 Clash 文档与教程,把 TUN、DNS 与策略组的关系一次理清。相比只靠运气换节点,结构化排障能省下的时间往往更多。

立即免费下载 Clash,开启流畅上网新体验