目录
DNS(Domain Names System)
域名转IP
IP转域名
域名
域名查询流程
浏览器DNS缓存
操作系统缓存
本地host文件
完整流程
递归查询
迭代查询
DNS(Domain Names System)
域名系统,将域名和 IP 地址进行转换的服务器。
域名转IP
在命令行中通过nslookup + 域名可以查看域名解析到ip
也可以在Chrome浏览器中chrome://net-internals/?#dns去输入域名查看ip
IP转域名
nslookup -qt=ptr ip地址,可以查看ip到域名的解析
域名
url链接由协议+主机+端口+路径组成,其中主机对应的部分为域名。域名组成是先写低级域名再写高级域名。
域名查询流程
1.查询浏览器的DNS缓存。(Chrome浏览器对每个域名会默认缓存60s,具体查看得通过网络日志查看)
浏览器DNS缓存
https://www.cnblogs.com/hls-code/p/17124489.html
2.查询操作系统DNS缓存
操作系统缓存
命令行中通过ipconfig/displaydns查看。
3.本地host文件
本地host文件
4.查询路由器DNS缓存(本地域名服务器)
5.迭代查询上级域名服务器,直到返回正确ip。
完整流程
1. 客户端发起一个DNS请求,先查看本地浏览器是否有这个域名的缓存,有解析结束
2. 没有则去看操作系统是否有缓存,有解析结束
3. 没有则去看本地host文件,有解析结束
4. 没有则发送该请求到本地DNS服务器,本地域名服务器采用递归查询自己的 DNS 缓存,如果本地DNS服务器存在则返回
5. 不存在本地DNS服务器则请求根域名服务器,比如请求"www.baidu.com",根域名服务器告诉本地DNS “.com” 顶级域名服务器的位置
6. 本地DNS服务器收到顶级域名服务器位置后则向顶级域名服务器请求"www.baidu.com"的IP地址,顶级域名服务器收到后则告诉本地DNS服务器"www.baidu.com"的权威域名服务器地址
7. 本地DNS服务器再向权威DNS服务器发起请求,权威DNS服务器查询后将对应的IP地址告诉本地DNS
8. 本地DNS服务器缓存该域名与对应IP然后返回IP给客户端
9. 浏览器根据TTL缓存该值
1-4为递归查询,5-7为迭代查询
递归查询
转发器将相应的查询结果返回至本地DNS服务器192.168.16.1,本地DNS服务器将查询结果返回至主机,最终得出http://qq.com的ns记录。因为本地DNS服务器不是http://qq.com的授权解析服务器,所以查询得出的结果是非权威应答。
递归的意思是:只需要发出一次请求,就能得到相应的结果。比如主机-本地DNS、本地DNS-转发器,都是递归查询。
迭代查询
本地域名服务器(本机)发起请求向根域名服务器,根域名服务器告诉本地域名服务器继续应该向谁查询,直到找到