有没有自动更新缓存的 DNS Server?

2022-06-18 19:37:02 +08:00
 JiaNa
有缓存的 DNS server 可以立刻给客户端返回结果,减少了请求 DNS 上游的时间,这个请求时间在 DNS over TLS 或者 DNS over HTTPS 上尤其长,我的平均时间是 300~400ms ,最大有 800ms ,在翻墙代理延迟 80ms 的情况下。

如果只增加 DNS 缓存时间而不自动更新会造成有些域名的 IP 不能及时更新,尤其是利用 DNS load balance 的,比如 Google 系的各种服务。
2245 次点击
所在节点    DNS
18 条回复
dcty
2022-06-18 19:50:22 +08:00
adg ,乐观缓存
JiaNa
2022-06-18 20:00:30 +08:00
@dcty
我试一下。

Adguard Home Optimistic DNS
> When the local DNS cache expires, Adguard Home can continue answer with the IP in the local cache results with 1 TTL, while a new DNS query is made to update the cache. If client can still connect to the server by using the old results, then that's great and reduces the time waiting for DNS query. And if not, after a short TTL, the new DNS result can be sent to client and reconnect again.
> https://github.com/AdguardTeam/AdGuardHome/issues/2145
ByteCat
2022-06-18 23:44:14 +08:00
路由器不应该自带这种功能么,RouterOS 和 爱快 我看都有,自建可以用 AdguardHome 也可以的。
Buges
2022-06-18 23:55:36 +08:00
这个功能应该由终端的操作系统(或网络库)实现,在任何中间 dns 转发器和递归解析器中实现很容易导致各种错误。应用无法区分错误是网络问题,还是已过期 dns 导致的,因而无法专门为已过期 dns 实现对应的重试行为。
如果链路中多个 dns 转发器都开了这种功能,那情况就更复杂了。
v2tudnew
2022-06-19 00:06:39 +08:00
用了乐观缓存后,下游 DDNS 用户都说好,亲自上门送菜刀。
ladypxy
2022-06-19 06:09:00 +08:00
adguard home 即可
yazoox
2022-06-19 07:12:54 +08:00
@ladypxy 这个是啥?安装在本机的一个软件?
gdyan2001
2022-06-19 07:53:59 +08:00
mosdns
JiaNa
2022-06-19 09:23:48 +08:00
@v2tudnew
我目前没有遇到问题。你遇到什么问题?对于过期的 DNS 记录,乐观缓存只返回 TTL 为 1 的 DNS 记录。下游有问题也只是 1 秒钟,等到 ADG 更新完之后,客户端再次请求,又是正确的了。
zhjits
2022-06-19 12:19:05 +08:00
v2tudnew
2022-06-19 12:56:53 +08:00
@JiaNa #9 有没有想过浏览器会强制 1TTL 缓存 60 秒?而且多子域名每个第一次打开都是上次的记录又要等 60 秒?
当然你可能没这么用。
JiaNa
2022-06-19 17:14:38 +08:00
我又尝试了 mosdns ,分流比 ADG 更好。问题是太少人用了,有坑或者问题得不到解答,要自己尝试以及前端界面不好。我打算用 mosh ,分流比前端更重要。
@gdyan2001
@ladypxy
@dcty
dcty
2022-06-19 17:53:03 +08:00
@JiaNa #12 其实我现在是套娃,adg 的上游是 mosdns ,mosdns 只用来分流
gdyan2001
2022-06-19 18:22:33 +08:00
bailliesun
2022-06-19 22:36:44 +08:00
NEXTDNS 有这个功能
yaott2020
2022-06-20 10:08:35 +08:00
mosdns 不错,我的方案是 mosdns+dnsmasq
xusp
2022-06-27 09:38:43 +08:00
@Buges 为什么递归解析器支持乐观缓存会导致问题?不理解!
Buges
2022-06-27 20:40:54 +08:00
@xusp #17 比如说你的站点换了新 IP ,但乐观解析返回了过期的缓存,客户端直接向旧 IP 发起连接,然后失败。
当然如果客户端本身支持对所有网络错误进行重试那是体现不出问题的。但很多场景客户端是不重试的,而乐观解析如果由客户端网络库实现,网络库就可以知道本次错误是由乐观解析导致的,进而帮你向新 IP 发起重试。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/860548

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX