DNS何时使用TCP与UDP协议?

DNS同时占用UDP和TCP端口53是公认的,这种单个应用协议同时使用两种传输协议的情况在TCP/IP栈也算是个另类。但很少有人知道DNS分别在什么情况下使用这两种协议。

DNS同时占用UDP和TCP端口53是公认的,这种单个应用协议同时使用两种传输协议的情况在TCP/IP栈也算是个另类。但很少有人知道DNS分别在什么情况下使用这两种协议。


TCP与UDP

TCP:面向连接的协议,提供可靠的数据传输,一般服务质量要求比较高的情况,使用这个协议。

UDP:用户数据报协议,是一种无连接的传输层协议,提供面向事务的简单不可靠信息传送服务。

DNS何时使用TCP与UDP协议?



TCP与UDP的区别

UDP和TCP协议的主要区别是两者在如何实现信息的可靠传递方面不同。

TCP协议中包含了专门的传递保证机制,当数据接收方收到发送方传来的信息时,会自动向发送方发出确认消息;发送方只有在接收到该确认消息之后才继续传送其它信息,否则将一直等待直到收到确认信息为止。

与TCP不同,UDP协议并不提供数据传送的保证机制。如果在从发送方到接收方的传递过程中出现数据报的丢失,协议本身并不能做出任何检测或提示。因此,通常人们把UDP协议称为不可靠的传输协议。

相对于TCP协议,UDP协议的另外一个不同之处在于如何接收突发性的多个数据报。不同于TCP,UDP并不能确保数据的发送和接收顺序。事实上,UDP协议的这种乱序性基本上很少出现,通常只会在网络非常拥挤的情况下才有可能发生。

既然UDP是一种不可靠的网络协议,那么还有什么使用价值或必要呢?其实不然,在有些情况下UDP协议可能会变得非常有用。因为UDP具有TCP所望尘莫及的速度优势。

虽然TCP协议中植入了各种安全保障功能,但是在实际执行的过程中会占用大量的系统开销,无疑使速度受到严重的影响。

反观UDP由于排除了信息可靠传递机制,将安全和排序等功能移交给上层应用来完成,极大降低了执行时间,使速度得到了保证。

DNS在进行区域传输的时候使用TCP协议,其它时候则使用UDP协议。

DNS的规范规定了2种类型的DNS服务器,一个叫主DNS服务器,一个叫辅助DNS服务器。

在一个区中主DNS服务器从自己本机的数据文件中读取该区的DNS数据信息,而辅助DNS服务器则从区的主DNS服务器中读取该区的DNS数据信息。当一个辅助DNS服务器启动时,它需要与主DNS服务器通信,并加载数据信息,这就叫做区传送(zone transfer)。


为什么既使用TCP又使用UDP?

首先了解一下TCP与UDP传送字节的长度限制:

UDP报文的最大长度为512字节,而TCP则允许报文长度超过512字节。当DNS查询超过512字节时,协议的TC标志出现删除标志,这时则使用TCP发送。通常传统的UDP报文一般不会大于512字节。

区域传送时使用TCP,主要有一下两点考虑:

  • 辅助域名服务器会定时(一般是3小时)向主域名服务器进行查询以便了解数据是否有变动。如有变动,则会执行一次区域传送,进行数据同步。区域传送将使用TCP而不是UDP,因为数据同步传送的数据量比一个请求和应答的数据量要多得多。
  • TCP是一种可靠的连接,保证了数据的准确性。


域名解析时使用UDP协议

客户端向DNS服务器查询域名,一般返回的内容都不超过512字节,用UDP传输即可。不用经过TCP三次握手,这样DNS服务器负载更低,响应更快。

虽然从理论上说,客户端也可以指定向DNS服务器查询的时候使用TCP,但事实上,很多DNS服务器进行配置的时候,仅支持UDP查询包。

原文地址:
https://www.linuxprobe.com/dns-tcp-udp.html

原创文章,作者:RPVRV,如若转载,请注明出处:https://www.wangzhanshi.com/n/14001.html

(0)
RPVRV的头像RPVRV
上一篇 2025年1月1日 17:04:58
下一篇 2025年1月1日 17:05:00

相关推荐

  • Windows Server 2008R2如何搭建DNS服务

    1、安装该服务,点击然后安装即可! ====安装完毕!!! 创建正面解析也就是域名转换IP地址www.ljq.com ———-172.16.16…

    2025年1月1日
  • Centos6.5下配置DNS服务器

    配置要求如下: 在服务器中安装配置bind服务,负责区域”xiangcheng.net” IP地址为10.100.100.x ,主机解析,五台主机分别为dn…

    2025年1月1日
  • k8s pod dns的问题记录是怎样的

    突然收到,反馈,一个服务短信验证码,验证很慢。第一反应是网络问题。 默认pod生成的dns 解析配置文件是如下: 由于pod 使用的是,alpine:latest 采用 apk a…

    2025年1月1日
  • 10步搞定DNS正向解析服务器设置(一)

    一安装DNS正向解析服务器1.yum-y install bind 安装dns2.安装完毕以后,用rpm -cp bind 查看 dns配置文件路径3.首先修改主配置文件,修改下图…

    2025年1月1日
  • dnsmasq如何配置dns

    DNSmasq是一个轻巧的,容易使用的DNS服务工具,它可以应用在内部网和Internet连接的时候的IP地址NAT转换,也可以用做小型网络的DNS服务。 dnsmasq先去解析h…

    2025年1月1日
  • 电脑出现网络dns异常的原因

    电脑出现网络dns异常的原因:1、网络故障,通常是DNS错误所致;2、网站故障,可能是网络服务器的线路发生意外堵塞,导致了一部分的用户无法打开网页;3、病毒所致。 电脑出现网络dn…

    2025年1月1日
  • DNS 正反向解析

    yum install bind -y #安装dns服务 vi /etc/named.conf #进入dns配置文件修改以下内容 listen-on port 53 { any; …

    2025年1月1日
  • 什么是DNS over HTTPS

    刚才的新闻中提到了DNS over  HTTPS这项技术,首先我们需要了解一下传统DNS上面存在的一些问题。 DNS的安全性缺陷 DNS全称Domain Name &nb…

    DNS解析 2025年1月1日
  • 如何解析squid的dns配置问题

    今天查了一下,squid对dns的支持是这样一个原理: 1、如果dns server发送域名时带有ttl,则以此ttl为准,一般dns server都会带有对ttl的支持,现在我用…

    DNS解析 2025年1月1日
  • 什么是DNS服务器

     DNS服务器是什么?DNS服务器其实就是域名解析服务器,这种服务器一般都是域名注册商那使用的,如果你的企业要从事域名注册,你就需要购买一个域名注册服务器了。这里网站那些…

    DNS解析 2025年1月1日

发表回复

登录后才能评论