V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
JiaNa
V2EX  ›  DNS

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

  •  
  •   JiaNa · 2022-06-18 19:37:02 +08:00 · 2029 次点击
    这是一个创建于 731 天前的主题,其中的信息可能已经有所发展或是发生改变。
    有缓存的 DNS server 可以立刻给客户端返回结果,减少了请求 DNS 上游的时间,这个请求时间在 DNS over TLS 或者 DNS over HTTPS 上尤其长,我的平均时间是 300~400ms ,最大有 800ms ,在翻墙代理延迟 80ms 的情况下。

    如果只增加 DNS 缓存时间而不自动更新会造成有些域名的 IP 不能及时更新,尤其是利用 DNS load balance 的,比如 Google 系的各种服务。
    18 条回复    2022-06-27 20:40:54 +08:00
    dcty
        1
    dcty  
       2022-06-18 19:50:22 +08:00 via Android
    adg ,乐观缓存
    JiaNa
        2
    JiaNa  
    OP
       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
        3
    ByteCat  
       2022-06-18 23:44:14 +08:00 via iPhone
    路由器不应该自带这种功能么,RouterOS 和 爱快 我看都有,自建可以用 AdguardHome 也可以的。
    Buges
        4
    Buges  
       2022-06-18 23:55:36 +08:00 via Android
    这个功能应该由终端的操作系统(或网络库)实现,在任何中间 dns 转发器和递归解析器中实现很容易导致各种错误。应用无法区分错误是网络问题,还是已过期 dns 导致的,因而无法专门为已过期 dns 实现对应的重试行为。
    如果链路中多个 dns 转发器都开了这种功能,那情况就更复杂了。
    v2tudnew
        5
    v2tudnew  
       2022-06-19 00:06:39 +08:00
    用了乐观缓存后,下游 DDNS 用户都说好,亲自上门送菜刀。
    ladypxy
        6
    ladypxy  
       2022-06-19 06:09:00 +08:00 via iPhone
    adguard home 即可
    yazoox
        7
    yazoox  
       2022-06-19 07:12:54 +08:00 via Android
    @ladypxy 这个是啥?安装在本机的一个软件?
    gdyan2001
        8
    gdyan2001  
       2022-06-19 07:53:59 +08:00
    mosdns
    JiaNa
        9
    JiaNa  
    OP
       2022-06-19 09:23:48 +08:00
    @v2tudnew
    我目前没有遇到问题。你遇到什么问题?对于过期的 DNS 记录,乐观缓存只返回 TTL 为 1 的 DNS 记录。下游有问题也只是 1 秒钟,等到 ADG 更新完之后,客户端再次请求,又是正确的了。
    zhjits
        10
    zhjits  
       2022-06-19 12:19:05 +08:00
    v2tudnew
        11
    v2tudnew  
       2022-06-19 12:56:53 +08:00
    @JiaNa #9 有没有想过浏览器会强制 1TTL 缓存 60 秒?而且多子域名每个第一次打开都是上次的记录又要等 60 秒?
    当然你可能没这么用。
    JiaNa
        12
    JiaNa  
    OP
       2022-06-19 17:14:38 +08:00
    我又尝试了 mosdns ,分流比 ADG 更好。问题是太少人用了,有坑或者问题得不到解答,要自己尝试以及前端界面不好。我打算用 mosh ,分流比前端更重要。
    @gdyan2001
    @ladypxy
    @dcty
    dcty
        13
    dcty  
       2022-06-19 17:53:03 +08:00
    @JiaNa #12 其实我现在是套娃,adg 的上游是 mosdns ,mosdns 只用来分流
    bailliesun
        15
    bailliesun  
       2022-06-19 22:36:44 +08:00 via Android
    NEXTDNS 有这个功能
    yaott2020
        16
    yaott2020  
       2022-06-20 10:08:35 +08:00 via Android
    mosdns 不错,我的方案是 mosdns+dnsmasq
    xusp
        17
    xusp  
       2022-06-27 09:38:43 +08:00 via Android
    @Buges 为什么递归解析器支持乐观缓存会导致问题?不理解!
    Buges
        18
    Buges  
       2022-06-27 20:40:54 +08:00
    @xusp #17 比如说你的站点换了新 IP ,但乐观解析返回了过期的缓存,客户端直接向旧 IP 发起连接,然后失败。
    当然如果客户端本身支持对所有网络错误进行重试那是体现不出问题的。但很多场景客户端是不重试的,而乐观解析如果由客户端网络库实现,网络库就可以知道本次错误是由乐观解析导致的,进而帮你向新 IP 发起重试。
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5261 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 29ms · UTC 07:10 · PVG 15:10 · LAX 00:10 · JFK 03:10
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.