【网络协议】聊聊HTTPDNS如何工作的

传统 DNS 存在哪些问题?

域名缓存问题

我们知道CND会进行域名解析,但是由于本地会进行缓存对应的域名-ip地址,所以可能出现过期数据的情况。
域名转发问题
出口 NAT 问题
域名更新问题
解析延迟问题

因为在解析DNS的时候,需要进行递归的遍历多个DNS服务器,这中间有一定的时延,所以会有时间延迟问题。

HTTPDNS的工作模式

既然DNS存在一定的问题, 那么又没有轻量级的DNS解析方式,HTTPDNS其实就是一种,使用HTTP协议进行DNS解析,请求服务器集群,获取最近的地址。

整体流程如下:

1.手机客户端请求HTTPDNS服务器,获取IP列表,缓存在本地,随着不断的解析域名,本地也会存储一份DNS解析结果的缓存数据。

2.如果从本地缓存可以获取数据,直接返回

3.如果从本地没有获取,那么直接请求HTTPDNS服务器,选择一个IP列表中一个发起HTTP请求。

4.HTTPDNS 服务会有智能调度和健康检查等接口。

HTTPDNS的缓存设计

为了提升读取速度,有自己的本地缓存。但是缓存的失效和更新如何保证呢。

对于HTTPDNS来说,就是手机客户端、DNS缓存、HTTPDNS服务器。

更新缓存的方式其实就是两种,一种是同步更新。也就是cache-Aside机制。先读取缓存,如果失效,读取源数据,然后设置更新缓存。

另一种是异步方式也就是快失效的时候,异步起一个线程进行处理。本质上来说DNS缓存,也需要有数据的持久化能力,保证数据不丢失。

HTTPDNS 的调度设计

调度设计其实就是需要根据不同的后端服务应用,给出一个优先响应列表,比如根据服务的容错率、健康检查、所在宿主机的配置、服务所在区域等进行调度,分配。

传统的 DNS 有很多问题,例如解析慢、更新不及时。因为缓存、转发、NAT 问题导致客户端误会自己所在的位置和运营商,从而影响流量的调度。

HTTPDNS 通过客户端 SDK 和服务端,通过 HTTP 直接调用解析 DNS 的方式,绕过了传统 DNS 的这些缺点,实现了智能的调度。

相关推荐
路星辞*1 小时前
基于访问表的安全防范策略
运维·网络·安全·智能路由器·acl
kaixin_啊啊1 小时前
静态路由配置与调试——计算机网络实训day1
网络·计算机网络
玖石书2 小时前
[IoT]物联网(IoT)网络的安全性
网络·物联网·智能路由器
DataDynamos数动实验室2 小时前
【计算机网络】IPSec的安全协议和封装模式
网络·计算机网络·网络安全
feiyangqingyun3 小时前
Qt监控系统远程网络登录/请求设备列表/服务器查看实时流/回放视频/验证码请求
服务器·网络·qt
JermeryBesian3 小时前
Flink系列知识讲解之:网络监控、指标与反压
大数据·网络·flink
xianwu5433 小时前
反向代理模块开发,
linux·开发语言·网络·c++·git
ybq195133454314 小时前
javaEE-网络原理-5.进阶 传输层UDP.TCP
网络·tcp/ip·udp
探索未来 航行现在4 小时前
网络基础知识--11
网络·tcp/ip·智能路由器
噠噠噠@4 小时前
HCIE-day10-ISIS
网络·网络协议·计算机网络