DNS概述

2020-03-03  本文已影响0人  GGBond_8488

DNS(Domain Name System)

Internet上主机。路由器识别问题

DNS服务

image.png
查询 www.amazon.com
先查根服务器 找到com域名解析服务器
查询com服务器 找到 amazon.com域名服务器
客户端查询amazon.com服务器,获得www.amazon.com的IP地址

DNS根服务器

TLD和权威域名解析服务器

本地域名解析服务器

不严格属于层级体系
每个ISP都有一个本地域名服务器
当主机进行DNS查询时,查询被发送到本地域名服务器,作为代理,将查转发给(层级式)域名解析服务器系统

DNS域名解析

1.迭代


image.png

2.递归


image.png

只要域名解析服务器获得域名-IP映射,就会缓存这一映射
一段时间后,缓存自动失效
本地域名服务器一般会缓存顶级域名服务器的映射,因此根域名服务器很少被访问

DNS记录和消息格式

资源记录(RR,resource records)

DNS使用的协议

DNS占用53号端口,同时使用TCP和UDP协议。那么DNS在什么情况下使用这两种协议

DNS在区域传输的时候使用TCP协议,其他时候使用UDP协议。

DNS区域传输的时候使用TCP协议:

1.辅域名服务器会定时(一般3小时)向主域名服务器进行查询以便了解数据是否有变动。如有变动,会执行一次区域传送,进行数据同步。区域传送使用TCP而不是UDP,因为数据同步传送的数据量比一个请求应答的数据量要多得多。

2.TCP是一种可靠连接,保证了数据的准确性。

域名解析时使用UDP协议:

客户端向DNS服务器查询域名,一般返回的内容都不超过512字节,用UDP传输即可。不用经过三次握手,这样DNS服务器负载更低,响应更快。理论上说,客户端也可以指定向DNS服务器查询时用TCP,但事实上,很多DNS服务器进行配置的时候,仅支持UDP查询包。

DNS协议:

image.png

2.1 头部

  1. 会话标识(2字节):是DNS报文的ID标识,对于请求报文和其对应的应答报文,这个字段是相同的,通过它可以区分DNS应答报文是哪个请求的响应

  2. 标志(2字节):

    image

    | QR(1bit) | 查询/响应标志,0为查询,1为响应 |
    | opcode(4bit) | 0表示标准查询,1表示反向查询,2表示服务器状态请求 |
    | AA(1bit) | 授权回答 |
    | TC(1bit) | 可截断的 |
    | RD(1bit) | 期望递归 |
    | RA(1bit) | 可用递归 |
    | rcode(4bit) | 表示返回码,0表示没有差错,3表示名字差错,2表示服务器错误(Server Failure) |

  3. 数量字段(总共8字节):Questions、Answer RRs、Authority RRs、Additional RRs 各自表示后面的四个区域的数目。Questions表示查询问题区域节的数量,Answers表示回答区域的数量,Authoritative namesversers表示授权区域的数量,Additional recoreds表示附加区域的数量

上一篇下一篇

猜你喜欢

热点阅读