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

先简单介绍下TCP与UDP。 
    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,主要有一下两点考虑: 
1.辅域名服务器会定时(一般时3小时)向主域名服务器进行查询以便了解数据是否有变动。如有变动,则会执行一次区域传送,进行数据同步。区域传送将使用TCP而不是UDP,因为数据同步传送的数据量比一个请求和应答的数据量要多得多。 
2.TCP是一种可靠的连接,保证了数据的准确性。

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

摘自:http://benbenxiongyuan.iteye.com/blog/1088085

转载于:https://www.cnblogs.com/bonelee/p/7089146.html

DNS同时占用UDP和TCP端口53——传输数据超过512时候用tcp,DNS服务器可以配置仅支持UDP查询包...相关推荐

  1. window下查看TCP端口连接情况:netstat -ano -p tcp|findstr 10001

    window下查看TCP端口连接情况:netstat -ano -p tcp|findstr 10001 netstat -an netstat -anb

  2. DNS使用TCP和UDP的端口号53

    DNS在两种情况下使用TCP 1.如果用wireshark.sniffer或古老些的tcpdump抓包分析,会发现几乎所有的情况都是在使用UDP,使用TCP的情况非常罕见.其实当解析器发出一个requ ...

  3. TCP 和 UDP 可以使用相同端口吗?

    之前有读者在面试的时候,被问到:TCP 和 UDP 可以同时监听相同的端口吗? 关于端口的知识点,还是挺多可以讲的,比如还可以牵扯到这几个问题: 多个 TCP 服务进程可以同时绑定同一个端口吗? 客户 ...

  4. 【虚拟机-虚拟网络】使用 PsPing PaPing 进行 TCP 端口连通性测试

    PsPing & PaPing 介绍 通常,我们测试数据包能否通过 IP 协议到达特定主机时,都习惯使用 ping 命令.工作时 ping 向目标主机发送一个 IMCP Echo 请求的数据包 ...

  5. 使用 PsPing PaPing 进行TCP端口连通性测试(转载)

    PsPing & PaPing 介绍 通常,我们测试数据包能否通过IP协议到达特定主机时,都习惯使用ping命令.工作时ping向目标主机发送一个ICMP Echo请求的数据包,并等待接收Ec ...

  6. 使用 PsPing PaPing 进行 TCP 端口连通性测试

    PsPing & PaPing 介绍 通常,我们测试数据包能否通过 IP 协议到达特定主机时,都习惯使用 ping 命令.工作时 ping 向目标主机发送一个 IMCP Echo 请求的数据包 ...

  7. php tcpping,【实践】如何检查TCP 端口连通性测试[psping和paping]

    背景 通常,我们测试数据包能否通过 IP 协议到达特定主机时,都习惯使用 ping 命令.工作时 ping 向目标主机发送一个 IMCP Echo 请求的数据包,并等待接收 Echo 响应数据包,通过 ...

  8. python探测端口_python检测远程服务器tcp端口的方法

    本文实例讲述了python检测远程服务器tcp端口的方法.分享给大家供大家参考.具体如下: python检测远程服务器tcp端口的代码,这段代码可以用来做服务器监控实用 #!/usr/bin/env ...

  9. 基于TCP端口扫描技术

    基于TCP全开的端口扫描技术 TCP扫描基本概念 TCP端口扫描工具的编写 TCP扫描基本概念 首先介绍第一种扫描技术--TCP全开扫描.这种扫描的思想很简单,如果目标端口是开放的,那么在接到主机端口 ...

最新文章

  1. 100+Python编程题给你练~(附答案)
  2. 让bind函数支持IE8浏览器的方法
  3. 「超全」工欲善其事必先利其器!
  4. wfs方式获取最短路径
  5. 堆元素插入 二叉堆一般用数组来表示。typedef struct _otherInfo{ int i; int j;}OtherInfo;-icoding-C-数据结构
  6. 浅谈Node.js(概念、安装、入门例子)
  7. linux进程管理 ps,Linux - 进程管理,ps与top
  8. 《穷爸爸富爸爸》读书笔记
  9. VUE如何关闭Eslint的方法
  10. java rgb565转rgb888_RGB565 转RGB888的循环补偿(zz)
  11. astah export sql mysql_Astah繪製UML圖形-入門篇
  12. 第五回 人似秋鸿来有信,事如春梦了无痕
  13. 计算机中带符号的整数表示方法,带符号数的代码表示-数字电子技术-电子发烧友网站...
  14. python画线段代码_python画线代码
  15. Android学习之CoordinatorLayout轻松实现360软件详情页
  16. 研究生可以不用学英语?只要考研英语或六级分数高!
  17. linux c语言lzma,LZMA 算法简介
  18. JVM调优之参数配置: -Xms -Xmx -Xmn -XX:+PrintGCDetails -XX:UseSerialGC -XX:SurvivorRadio -XX:NewRadio
  19. 嵌入式系统的软件看门狗和硬件看门狗
  20. pycharm提示softmax() got an unexpected keyword argument 'axis'错误

热门文章

  1. epoll_wait被signal信号中断时的处理
  2. win10 修改gitlab账号_玩转gitlab + jenkins
  3. python库管理_多版本python控制以及python三方库管理
  4. mac睡眠快捷键_mac键盘快捷键大全
  5. html如何用v-for遍历,v-for循环遍历
  6. 空气培养皿采样后保存_环境监测基础知识——环境空气监测技术之布点采样
  7. mysql的索引类型以及优缺点
  8. Java开发面试技巧,Hive-JDBC操作
  9. 保洁阿姨看完都会了!java导出excel并下载详解
  10. 【深度学习入门到精通系列】开始恢复更新通知~!