DNS 扩展篇:从会配记录,到真正能排查 DNS 问题

上一篇聊完普通解析、泛域名解析、A 记录、TXT 记录、普通证书和通配证书之后,我对 DNS 的理解已经比以前清楚很多了。

以前我对 DNS 的理解基本停留在:

域名 -> IP

也就是:

A 记录

后来才发现,DNS 不只是“把域名解析成 IP”。

它还承担了:

命名
寻址
验证
策略
委派
缓存
排障

这些角色。

这篇算是 DNS 的扩展篇,整理一下接下来还值得补的内容。

目标不是背概念,而是让自己以后遇到 DNS、证书、域名、Caddy、Cloudflare、阿里云解析这些问题时,能知道从哪里下手排查。


一、DNS 不只是 A 记录

我以前最熟悉的是 A 记录:

abc.weini.xin A 123.123.123.123

意思是:

abc.weini.xin 解析到 123.123.123.123

但 DNS 里还有很多记录类型。

比较常见的有:

A      域名 -> IPv4
AAAA   域名 -> IPv6
CNAME  域名 -> 另一个域名
TXT    域名 -> 一段文本
MX     邮件服务器
NS     这个域名由哪些 DNS 服务器管理
CAA    允许哪些证书机构给这个域名签发证书

这里面我觉得最值得优先理解的是:

CNAME
NS
CAA
TXT

因为它们和日常建站、证书、Cloudflare、邮件、安全关系很大。


二、A 记录:最直观的寻址

A 记录是最常见的 DNS 记录。

它的作用是:

域名 -> IPv4 地址

比如:

weini.xin A 39.106.128.214

意思是:

访问 weini.xin 时,去 39.106.128.214 这台服务器

如果是泛域名:

*.dev.weini.xin A 39.106.128.214

意思是:

所有 xxx.dev.weini.xin 都去 39.106.128.214

A 记录解决的是:

这个名字应该去哪台 IPv4 服务器?

它是 DNS 里最基础的寻址能力。


三、AAAA 记录:IPv6 版本的 A 记录

AAAA 记录和 A 记录类似,只不过它指向的是 IPv6 地址。

比如:

abc.weini.xin AAAA 2408:xxxx:xxxx::1

A 记录负责 IPv4:

123.123.123.123

AAAA 记录负责 IPv6:

2408:xxxx:xxxx::1

现在很多服务器、CDN、云厂商都支持 IPv6。

如果未来自己的服务需要支持 IPv6,就会碰到 AAAA 记录。

现在不一定马上用,但要知道它存在。


四、CNAME:别名,不是直接指向 IP

CNAME 很常见。

它的作用是:

一个域名是另一个域名的别名

比如:

www.weini.xin CNAME weini.xin

意思是:

www.weini.xin 不直接写 IP
而是跟随 weini.xin 的解析结果

还有很多 CDN 或云服务会让你配置 CNAME。

比如某个平台给你一个地址:

xxx.cdn-provider.com

它会让你配置:

static.weini.xin CNAME xxx.cdn-provider.com

这样访问:

static.weini.xin

实际会跟着平台给的那个域名走。

CNAME 的好处是,目标服务的 IP 以后变化了,你不用管。因为你指向的是它的域名,不是固定 IP。

CNAME 要注意什么?

一个常见规则是:

同一个主机记录如果配置了 CNAME,一般不能再同时配置 A、MX 等其他记录。

比如你已经有:

www.weini.xin CNAME weini.xin

就不要再给 www.weini.xin 配:

www.weini.xin A 1.2.3.4

否则容易冲突。


五、TXT:不是访问用的,而是声明和验证用的

TXT 记录返回的是字符串。

比如:

_acme-challenge.dev.weini.xin TXT "abcdefg"

它不是告诉浏览器访问哪台服务器。

它只是公开声明:

_acme-challenge.dev.weini.xin 这个名字下面有一段文本 abcdefg

TXT 的用途很多:

证书 DNS 验证
Google / GitHub / 各种平台的域名所有权验证
SPF 邮件防伪
DKIM 邮件签名
DMARC 邮件策略
一些服务商的配置声明

之前理解通配证书时,TXT 记录就很关键。

通配证书申请时,证书机构会要求你添加类似:

_acme-challenge.dev.weini.xin TXT "随机验证码"

证书机构查询 DNS,发现字符串一致,就证明你能控制这个域名的 DNS。

所以 TXT 很重要。

它不是寻址记录,而是:

验证 / 声明 / 策略记录

六、MX:邮件服务器

MX 记录是给邮件用的。

比如:

weini.xin MX 10 mail.weini.xin

意思是:

发给 xxx@weini.xin 的邮件,应该交给 mail.weini.xin 这台邮件服务器

如果以后自己搞企业邮箱、域名邮箱,就一定会碰到 MX。

很多邮箱服务商会让你配置:

MX
TXT
CNAME

一整套记录。

MX 负责收邮件路径。

TXT 里的 SPF、DKIM、DMARC 负责邮件防伪和信誉。

如果只是建站,MX 不重要。

如果要用自己的域名发收邮件,它就很重要。


七、NS:谁负责管理这个域名的解析

NS 记录非常关键。

它回答的问题是:

这个域名由哪些 DNS 服务器负责解析?

比如:

weini.xin NS ns1.alidns.com
weini.xin NS ns2.alidns.com

这说明:

weini.xin 的权威 DNS 在阿里云

如果你把 DNS 托管到 Cloudflare,那么 NS 可能会变成:

xxx.ns.cloudflare.com
yyy.ns.cloudflare.com

这就意味着:

weini.xin 的解析权交给 Cloudflare 管了

这点非常重要。

因为域名注册商和 DNS 托管商不是一回事。

比如:

域名可以在阿里云买
DNS 可以交给 Cloudflare 管
服务器可以在另一家云厂商

这三个东西可以分开。

我以前容易把“在哪里买域名”和“在哪里配置 DNS”混在一起。

现在理解 NS 后,就清楚多了。

NS 决定权威 DNS 在哪里。

你应该去权威 DNS 那里改记录。


八、CAA:限制谁能给我的域名发证书

CAA 是一个和证书安全有关的 DNS 记录。

它的作用是告诉证书机构:

哪些 CA 可以给我的域名签发证书

比如:

weini.xin CAA 0 issue "letsencrypt.org"

意思是:

只允许 Let's Encrypt 给 weini.xin 签发证书

如果你还用 ZeroSSL,也可以加:

weini.xin CAA 0 issue "sectigo.com"

CAA 不是必须配置。

很多人不配也没问题。

但知道它存在很重要。

因为它说明 DNS 不只是寻址,还可以表达安全策略。

如果以后想提高域名证书安全,可以研究 CAA。


九、权威 DNS 和递归 DNS

这是 DNS 里非常关键的一层。

我以前容易以为 DNS 就是一个地方。

实际上 DNS 查询里有不同角色。

递归 DNS

你电脑、路由器、系统里常见的 DNS:

8.8.8.8
1.1.1.1
114.114.114.114
223.5.5.5

这些通常是递归 DNS。

它们的作用是:

帮你去查最终结果

你问它:

mcp.dev.weini.xin 是多少?

它会一步一步帮你查,然后返回答案。

权威 DNS

权威 DNS 才是某个域名记录的最终来源。

比如 weini.xin 的 NS 指向阿里云 DNS,那么阿里云 DNS 就是 weini.xin 的权威 DNS。

你在阿里云控制台添加:

*.dev.weini.xin A 39.106.128.214

这个记录最终存在阿里云的权威 DNS 上。

递归 DNS 只是帮别人查询和缓存。

查询链路大概是这样

你的电脑
  ↓
递归 DNS,比如 8.8.8.8
  ↓
根 DNS
  ↓
顶级域 DNS,比如 .xin
  ↓
weini.xin 的权威 DNS
  ↓
返回记录

所以改 DNS 记录时,要知道:

我应该去权威 DNS 那里改
不是去递归 DNS 那里改

十、TTL:为什么 DNS 不是你一改就全世界立刻生效

TTL 是 DNS 记录的缓存时间。

比如一条记录:

mcp.dev.weini.xin A 39.106.128.214 TTL 600

意思是:

递归 DNS 查到这个结果后,可以缓存 600 秒

也就是 10 分钟。

如果 TTL 是 3600,就可以缓存 1 小时。

所以 DNS 修改不是全世界瞬间同步。

你改了权威 DNS 后,有些递归 DNS 可能还在用旧缓存。

这就是为什么经常出现:

我控制台明明改了
为什么本地还是旧 IP?
为什么我这里生效了,别人那里没生效?

可能就是 TTL 和缓存导致的。

实用经验

正式切换 IP 前,可以提前把 TTL 调低,比如:

60
300
600

等切换稳定后,再调高:

3600
7200

开发测试域名可以 TTL 短一点。

正式稳定域名可以 TTL 长一点。


十一、DNS 排障不能只看控制台,要学会 dig

只看 DNS 控制台是不够的。

因为控制台显示的是你配置了什么。

但外部真实查询结果是什么,要用工具查。

最常用的是:

dig

查 A 记录

dig mcp.dev.weini.xin

或者简洁一点:

dig +short mcp.dev.weini.xin

查 TXT 记录

dig TXT _acme-challenge.dev.weini.xin

简洁版:

dig +short TXT _acme-challenge.dev.weini.xin

查 NS

dig NS weini.xin

查 CAA

dig CAA weini.xin

指定递归 DNS 查询

dig @8.8.8.8 mcp.dev.weini.xin
dig @1.1.1.1 mcp.dev.weini.xin
dig @223.5.5.5 mcp.dev.weini.xin

这个很有用。

因为你可以比较不同递归 DNS 的结果是否一致。

查完整链路

dig +trace mcp.dev.weini.xin

这个会从根开始追踪整个查询过程。

排查复杂 DNS 问题时很有用。


十二、nslookup 也能用,但 dig 更适合排障

Windows 上很多人习惯用:

nslookup mcp.dev.weini.xin

查 TXT:

nslookup -type=TXT _acme-challenge.dev.weini.xin

查 NS:

nslookup -type=NS weini.xin

nslookup 能用,而且系统自带,方便。

但如果是认真排障,我更推荐 dig。

因为 dig 输出更清晰,也更适合指定 DNS、查 trace、查不同记录类型。


十三、DNS 解析和 HTTP 路由一定要分清楚

这个是我这次最重要的理解之一。

DNS 只负责:

这个域名应该去哪个 IP

但到了服务器之后,具体交给哪个服务,不是 DNS 决定的。

比如:

mcp.dev.weini.xin
api.dev.weini.xin
demo.dev.weini.xin

它们通过泛解析都到了同一个 IP:

39.106.128.214

DNS 的工作到这里就结束了。

后面要靠 Caddy 或 frp 根据 HTTP Host 分流:

Host: mcp.dev.weini.xin -> 服务 A
Host: api.dev.weini.xin -> 服务 B
Host: demo.dev.weini.xin -> 服务 C

所以要记住:

DNS 负责到服务器
Caddy/Nginx/frp 负责到服务

如果一个域名能 ping 到服务器,但访问 404,那不一定是 DNS 错。

可能是 Caddy 没配置对应站点。

如果 HTTPS 证书不对,也不一定是 DNS 错。

可能是证书没签好、Host 不匹配、Caddy 配置没生效。

分层看问题,排障会清楚很多。


十四、DNS 和 HTTPS 证书的关系

证书这块也要重新理解。

普通证书:

abc.weini.xin

通常可以用 HTTP 验证。

证书机构访问:

http://abc.weini.xin/.well-known/acme-challenge/xxx

DNS 把它带到服务器。

Caddy 返回随机验证码。

证书机构验证通过,发证书。

通配证书:

*.dev.weini.xin

不能用 HTTP 验证,因为 * 不是具体域名。

所以要用 DNS TXT 验证:

_acme-challenge.dev.weini.xin TXT "随机验证码"

证书机构查 DNS,确认验证码一致,发通配证书。

所以 DNS 在证书体系里有两个角色:

普通证书:DNS 负责带路
通配证书:DNS 负责证明控制权

十五、DNS 也参与邮件安全

以后如果要用自己的域名发邮件,就会遇到更多 DNS 记录。

比如:

MX
SPF
DKIM
DMARC

简单理解:

MX

决定谁收邮件。

weini.xin 的邮件交给哪个邮件服务器

SPF

通过 TXT 记录声明:

哪些服务器可以代表我这个域名发邮件

DKIM

通过 TXT 记录放公钥。

收件方可以用它验证邮件签名。

DMARC

告诉收件方:

如果发现伪造邮件,应该怎么处理

比如:

直接拒收
标记垃圾邮件
只上报不处理

这块暂时不一定要深入,但要知道:

邮件系统大量依赖 DNS TXT 来证明身份和设置策略。

这也再次说明,DNS 不是简单的域名转 IP。


十六、域名规划也很重要

技术之外,域名规划本身也很重要。

我现在比较认可这种分层:

weini.xin              正式主站
www.weini.xin          正式入口
api.weini.xin          正式 API
blog.weini.xin         博客

*.dev.weini.xin        开发服务
*.test.weini.xin       测试服务

这种结构的好处是:

正式服务清晰
开发服务自由
测试服务自由
主域名空间不被污染

不要一上来就直接:

*.weini.xin

因为这个范围太大。

它会覆盖所有一级子域名:

mail.weini.xin
admin.weini.xin
cdn.weini.xin
random.weini.xin

不是不能用,但管理边界会变差。

更稳的是把泛域名放到二级命名空间下面:

*.dev.weini.xin
*.test.weini.xin

这就是一种简单的域名治理。


十七、我后面最应该补的三个方向

如果只挑三个最值得继续补的 DNS 知识,我觉得是:

1. 权威 DNS vs 递归 DNS
2. TTL 和缓存
3. dig 排障

这三个掌握以后,遇到 DNS 问题就不会只会猜。

比如遇到问题时,可以问自己:

我是在权威 DNS 改的吗?
递归 DNS 有没有缓存旧结果?
不同 DNS 查询结果一致吗?
TTL 是多少?
Caddy 是否真的收到了这个 Host?
证书是否匹配这个域名?

这就从“配置型理解”变成了“排障型理解”。


十八、最后总结

这一轮 DNS 学下来,我觉得自己的理解明显升级了。

以前:

DNS = A 记录 = 域名指向 IP

现在:

DNS = 命名系统 + 寻址系统 + 验证系统 + 策略系统

A 记录解决:

去哪个 IPv4

AAAA 记录解决:

去哪个 IPv6

CNAME 解决:

这个名字是谁的别名

TXT 解决:

这个名字公开声明了什么字符串

MX 解决:

邮件交给谁

NS 解决:

这个域名由谁管理解析

CAA 解决:

哪些证书机构可以发证书

TTL 决定:

结果能缓存多久

dig 帮助我们:

从外部真实查询 DNS

这套东西理解之后,再看 Caddy 自动 HTTPS、frp 泛域名、通配证书、Cloudflare、阿里云 DNS、邮箱验证,就不会那么迷糊了。

DNS 的确不只是“域名解析”。

它是互联网服务入口背后的基础设施层。

Read more

三台机器部署 ClickHouse 高可用集群实战记录

本文是一份可发布版部署记录。真实 IP、域名、账号、密码、下载链接、业务目录名、机器唯一标识等敏感信息已经替换为占位符。命令中的 <...> 需要按自己的环境替换。 目标与拓扑 这次目标是用三台数据节点部署一套 ClickHouse 高可用集群,拓扑采用: 1 shard x 3 replicas 含义是:集群只有一个逻辑分片,三台机器都保存同一份数据的完整副本。任意一台数据节点宕机时,只要 ClickHouse Keeper 仍然有多数派,剩余节点仍可继续提供读写服务。 规划节点如下: 主机名示例地址角色ch-01<ch-01-ip>ClickHouse Server + ClickHouse Keeperch-02<ch-02-ip>ClickHouse Server + ClickHouse Keeperch-03<ch-03-ip&

By ladydd

折腾记(二):接入火山引擎实时语音 API,家庭语音助手体验直接拉满

接上篇 上一篇用全开源组件(Whisper + Hermes + Edge-TTS)搭了个语音助手,能跑,但体验就是"能用"二字: * 中文识别只有 70 分,方言基本歇菜 * 英文唤醒词"Alexa"喊着别扭 * 说完到回复要等 4-8 秒 * 它说话的时候你插不了嘴 这些问题靠堆开源组件很难根治。于是我去试了火山引擎(字节跳动)的语音服务,结果直接换了条路。 这篇分两段:先讲怎么用火山引擎的 ASR/TTS 替换掉开源组件(小改),再讲怎么上端到端实时语音模型(大改)。 第一段:先把 ASR 和 TTS 换成火山引擎 为什么换 我用豆包输入法的时候发现它语音识别准得离谱。一查,豆包用的就是字节自家的火山引擎 Seed-ASR。开通后有免费额度(

By ladydd

折腾记(一):用全开源组件给家里搭一个语音助手,对接自己的 Hermes Agent

起因 事情是从一块 ESP32-S3 开发板开始的。 我手上有一块 Seeed Studio XIAO ESP32-S3 Sense,带摄像头和麦克风。最初的想法很美好:用这块板子做一个无线语音终端,对着它说话,连到我服务器上跑的 Hermes Agent(一个自托管的 AI agent),让它回答我。 但折腾到一半我突然意识到一件事:我的麦克风、音响、服务器全在家里,为什么要绕一圈用 ESP32?直接把麦克风和音响插到服务器上不就行了? ESP32 那条路(做无线拾音终端)当然也有价值,但那是"为了学嵌入式而学",不是解决问题的最短路径。于是这个项目就从"嵌入式项目"变成了"在服务器上拼一个语音助手"。这篇就记录后者。 教训零:先想清楚你要解决的是什么问题。很多时候最优解比你最初设想的简单得多。 目标

By ladydd

Kiro 的三种代理设置方法:本地、服务端、Remote

作为kiro的骨灰级用户,这篇是我自己折腾 Kiro / Kiro Remote / Ubuntu Server 代理问题后的复盘。 核心不是“怎么配一个代理”,而是先判断:到底是谁在访问外网? 谁访问外网,代理就要配给谁。 0. 先说结论 Kiro 相关代理大概分三类: 场景真正访问外网的进程在哪里代理应该配在哪里本地 KiroWindows / Mac 本机本机 Clash / Proxifier / 系统代理服务端 Kiro / CLIUbuntu Server 上的 shell、CLI、node、kiro 进程Ubuntu 的环境变量,比如 HTTP_PROXY / HTTPS_PROXYKiro Remote远程 Ubuntu 上的 ~/.kiro-server 和 extensionHost远程 Ubuntu 的 Kiro Server

By ladydd
陕公网安备61011302002223号 | 陕ICP备2025083092号