目录

一、TCP和UDP都属于TCP/IP协议族

二、UDP和TCP的不同

2.1  TCP是面向连接的,UDP是面向无连接的

2.2  TCP是可靠的,UDP是不可靠的

2.3   TCP是面向字节流的,UDP是面向报文的

2.4  TCP只有一对一的传输方式,而UDP不仅可以一对一,还可以一对多,多对多

2.5   UDP的头部开销小,TCP的头部开销大

2.6  TCP会产生粘包问题,UDP会产生丢包问题

2.6.1  TCP粘包

2.6.2  UDP丢包问题

三、总结


一、TCP和UDP都属于TCP/IP协议族

TCP/IP模型是一些列协议的总称(比如:TCP,UDP,IP,FTP,HTTP,ICMP,SMTP)。这些协议可以划分为四层:链路层、网络层、传输层、应用层。

二、UDP和TCP的不同

2.1  TCP是面向连接的,UDP是面向无连接的

UDP是不需要和TCP一样建立三次握手连接的。而TCP则在通信前是需要进行三次握手的。

具体就是:

  • 在发送端,应用层将数据传递给传输层的UDP协议,UDP只会给数据增加一个UDP头,标识是UDP协议,然后就传递给网络层了。
  • 在接收端,网络层将数据传递给传输层,UDP只去除IP报文头就传递给应用层了,不做任何拼接操作。

2.2  TCP是可靠的,UDP是不可靠的

  • 具体体现在,UDP的无连接上,通信都不需要建立连接,想发就发,这样的情况肯定不可靠。
  • 发送数据也不会关心对方是否已经正确接收到数据。
  • 其次,网络环境时好时坏,但是UDP是没有拥塞控制的,一直会以恒定的速度发送数据。就算网络不好,也不会对发送速率作调整,这样就会在网络不好时,可能产生丢包。但是优点野明显,就是对于一些实时性要求高的场景(比如电话会议)就需要UDP,因为远程视频的话,你丢一些数据(例如像素)并不影响视频的内容。

从上面的动态图可以得知,UDP只会把想发的数据报文一股脑的丢给对方,并不在意数据有无安全完整到达。

在TCP协议中使用了接收确认和重传机制,使得每一个信息都能保证到达,是可靠的。

而UDP是尽力传送,没有应答和重传机制,UDP只是将信息发送出去,对方收不收到也不进行应答。所以UDP协议是不可靠的。

2.3   TCP是面向字节流的,UDP是面向报文的

怎么理解面向字节流和面向报文呢?

TCP基于流的传输表示TCP不认为消息是一条一条的,是无保护消息边界的(保护消息边界:指传输协议把数据当做一条独立的消息在网上传输,接收端一次只能接受一条独立的消息)。

UDP面向报文,是有 保护消息边界 的,接收方一次只能接受一条独立的消息,所以UDP不存在粘包。

举个例子:有三个数据包,大小分别为2k、4k、6k,如果采用UDP发送的话,不管接受方的接收缓存有多大,我们必须要进行至少三次以上的发送才能把数据包发送完,但是使用TCP协议发送的话,我们只需要接受方的接收缓存有12k的大小,就可以一次把这3个数据包全部发送完毕,那么就会造成接收方一次会接收不止一条消息,这就是粘包

2.4  TCP只有一对一的传输方式,而UDP不仅可以一对一,还可以一对多,多对多

UDP 不止支持一对一的传输方式,同样支持一对多,多对多,多对一的方式,也就是说 UDP 提供了单播,多播,广播的功能。

TCP不能一对多的原因是:TCP通信前要跟一台主机进行三次握手连接,因此TCP不能对多。

2.5   UDP的头部开销小,TCP的头部开销大

 UDP头部

UDP的头部很小,只有8个字节。相比TCP至少20个字节,UDP头部要小得多。

下图是一个UDP数据包:可以看到,头部数据由4部分组成:源端口号、目的端口号、总长度(即UDP头部+数据的长度)、校验和

TCP头部

可以看到,TCP的头部至少要20个字节。

2.6  TCP会产生粘包问题,UDP会产生丢包问题

2.6.1  TCP粘包

TCP产生粘包问题的主要原因是:TCP是面向连接的,所以在TCP看来,并没有把消息看成一条条的,而是全部消息在TCP眼里都是字节流,因此A、B消息混在一起后,TCP就分不清了。

来一个图展示一下TCP粘包情况:

可以看到,第一次read数据,读了5个字节,但是第一个数据有10个字节啊,没办法,就只能下次再读,第二次read数据,读25个字节,就会把后面的数据也一起读了,这就是粘包情况。

粘包问题的最本质原因在与接收对等方无法分辨消息与消息之间的边界在哪。我们通过使用某种方案给出边界,例如:

  • 包头加上包体长度。包头是定长的4个字节,说明了包体的长度。接收对先接收包体长度,依据包体长度来接收包体。

2.6.2  UDP丢包问题

由于UDP是没有应答和重传机制,因此包很容易传丢了也不知道。

  1. 主要丢包原因:接收端处理时间过长导致丢包:调用recv方法接收端收到数据后,处理数据花了一些时间,处理完后再次调用recv方法,在这二次调用间隔里,发过来的包可能丢失。对于这种情况可以修改接收端,将包接收后存入一个缓冲区,然后迅速返回继续recv。
  2. 发送的包巨大丢包:虽然send方法会帮你做大包切割成小包发送的事情,但包太大也不行。例如超过50K的一个udp包,不切割直接通过send方法发送也会导致这个包丢失。这种情况需要切割成小包再逐个send。
  3. 发送的包较大,超过接受者缓存导致丢包:包超过mtu size(mtu表示最大传输单元)数倍,几个大的udp包可能会超过接收者的缓冲,导致丢包。这种情况可以设置socket接收缓冲。以前遇到过这种问题,我把接收缓冲设置成64K就解决了。
  4. 发送的包频率太快:虽然每个包的大小都小于mtu size 但是频率太快,例如40多个mut size的包连续发送中间不sleep,也有可能导致丢包。

三、总结

TCP和UDP的区别相关推荐

  1. TCP和UDP的区别(转)

    TCP协议与UDP协议的区别     首先咱们弄清楚,TCP协议和UCP协议与TCP/IP协议的联系,很多人犯糊涂了,一直都是说TCP/IP协议与UDP协议的区别,我觉得这是没有从本质上弄清楚网络通信 ...

  2. 5.TCP和UDP的区别

    定义:TCP(Transmission ControlProtocol 传输控制协议)是一种面向连接的.可靠的.基于字节流的传输层通信协议,由IETF的RFC 793定义.在简化的计算机网络OSI模型 ...

  3. tcp和udp的区别和三次 四次挥握手 http://www.cnblogs.com/bizhu/archive/2012/05/12/2497493.html...

    小结TCP与UDP的区别: 1.基于连接与无连接: 2.对系统资源的要求(TCP较多,UDP少): 3.UDP程序结构较简单: 4.流模式与数据报模式 : 5.TCP保证数据正确性,UDP可能丢包,T ...

  4. 【转】TCP和UDP的区别

    TCP协议与UDP协议的区别 首先咱们弄清楚,TCP协议和UDP协议与TCP/IP协议的联系,很多人犯糊涂了, 一直都是说TCP协议与UDP协议的区别,我觉得这是没有从本质上弄清楚网络通信! TCP/ ...

  5. udp 使用connect优点_一文搞懂TCP和UDP的区别

    TCP(Transmission Control Protocol,传输控制协议)和UDP(User Data Protocol ,用户数据报协议)都属于TCP/IP协议簇.TCP/IP协议集包括了超 ...

  6. TCP和UDP的区别(Socket)

    TCP和UDP区别 TCP和UDP编程区别 TCP编程的服务器端一般步骤是: 1.创建一个socket,用函数socket(): 2.设置socket属性,用函数setsockopt(); * 可选 ...

  7. 网络通信tcp与udp的区别

    tcp与udp的区别 网络udp概述 UDP 是User Datagram Protocol的简称, 中文名是用户数据报协议.一种无连接的传输层协议,提供面向事务的简单不可靠信息传送服务.类似于日常生 ...

  8. TCP/IP的初步理解,TCP和UDP的区别

    1.什么是TCP/IP协议 TCP/IP协议是一个协议簇.里面包括很多协议的.UDP只是其中的一个.之所以命名为TCP/IP协议,因为TCP,IP协议是两个很重要的协议,就用他俩命名了. TCP/IP ...

  9. 传输层协议TCP和UDP的区别详解

    一.TCP协议 1.TCP的优点: 可靠,稳定 TCP的可靠体现在TCP在传递数据之前,会有三次握手来建立连接,而且在数据传递时,有确认.窗口.重传.拥塞控制机制,在数据传完后,还会断开连接用来节约系 ...

  10. TCP和UDP的区别有哪些

    TCP和UDP的区别有哪些 传输层协议主要有TCP与UDP. UDP:提供无连接的通信,不能保证数据包被发送到目的地址,典型的即时传输少量数据的应用程序使用UDP TCP:面向连接的.可靠地.基于字节 ...

最新文章

  1. django中的for循环_深入了解 JavaScript 中的 for 循环
  2. HBase、Redis、MongoDB、Couchbase、LevelDB 五款主流NoSQL数据库大比拼
  3. 如何基于OceanBase构建应用和数据库的异地多活
  4. java控制语句案例_Java基础语法—流程控制语句
  5. 从小编程,到架构师,我们应该具备什么
  6. 哨兵卫星及数据下载平台介绍
  7. python中文版下载-python3.8.1汉化版
  8. Windows Server 2008 R2远程桌面服务配置和授权激活
  9. android fastboot模式下载以及出现的问题
  10. 通用无线公共接口cpri学习笔记_11/24
  11. Zynga公布2020年第二季度财务业绩
  12. 腾讯WeTestTesterHome深圳线下沙龙
  13. 2021 年高教社杯全国大学生数学建模竞赛 E 题 中药材的鉴别 第一题
  14. etal斜体吗 参考文献_参考文献方面毕业论文格式模板,与文下载****北京化工大学学报相关论文下载...
  15. JavaScript 页面资源加载:onload,onerror
  16. 2014 计算机一级 试题,2014年全国计算机一级考试选择题试题与详细答案
  17. HCIA(5)动态路由实验
  18. 海康威视网络监控摄像头常见设置-工作随笔
  19. 配置eyeOS系统--6--后记
  20. [XCTF-Reverse] 58-61

热门文章

  1. 南京邮电大学高级语言程序设计实验二(选择与循环结构编程)
  2. H3CSE路由-企业网模型
  3. 天天红单app下载安装_天天红单官网下载
  4. [教程]黑莓终极中文混刷教程 终身受用
  5. 真实的网络赚钱经历:另类推广引流操作CPA!
  6. 走进四维空间-我们如何理解时空
  7. Aladdin HASP加密狗破解脱壳笔记
  8. SSL自签名证书制作方法
  9. 好用的万年历API推荐
  10. Git之git pull【warning】Pulling without specifying how to reconcile divergent branches is