天天看点

TCP与UDP异同TCP与UDP异同

TCP与UDP异同

TCP/IP

模型的运输层有两个不同的协议:

UDP

用户数据报协议与

TCP

传输控制协议

相同点

  • TCP

    UDP

    都是运行在运输层的协议
  • TCP

    UDP

    的通信都需要开放端口

不同点

TCP

  • TCP

    是面向连接的协议,提供全双工通信,需要建立链接之后再传输数据,数据传输负载相对较大。
  • TCP

    提供可靠交付的服务,使用流量控制和拥塞控制等服务保证可靠通信。
  • TCP

    首部最小

    20

    字节,最大

    60

    字节,包括源端口、目的端口、序号、确认号、数据偏移、控制标志、窗口、校验和、紧急指针、选项等信息。
  • TCP

    只能是一对一通信。
  • TCP

    面向字节流通信。
  • TCP

    保证数据传输的顺序,通过给

    TCP

    连接中传送数据流的每个字节都编上序号来确定传输顺序。
  • TCP

    提供校验和、确认应答、序列号、超时重传、连接管理、流量控制、拥塞控制等功能。
  • TCP

    适用于要求可靠传输的应用,如文件传输等

UDP

  • UDP

    是无连接的,即发送数据之前不需要建立连接,数据传输负载相对较小。
  • UDP

    使用尽最大努力交付,即不保证可靠交付,同时也不使用流量控制和拥塞控制。
  • UDP

    首部

    8

    字节,包括源端口、目的端口、长度、校验和信息。
  • UDP

    具有单播、多播、广播的功能,支持一对一、一对多、多对多、多对一的数据传输方式。
  • UDP

    是面向报文通信,对应用层交下来的报文,既不合并,也不拆分,而是保留这些报文的边界,在添加首部后就向下交付

    IP

    层。
  • UDP

    不保证数据传输的顺序,需要应用层程序在数据段加入序号等方式控制顺序。
  • UDP

    只在

    IP

    的数据报服务之上增加了很少一点的功能,即端口的功能和差错检测的功能。
  • UDP

    适用于实时应用,如网络电话、视频会议、直播等

相关问题

UDP实现可靠性传输

运输层无法保证数据的可靠传输,只能通过应用层来实现了,实现的方式可以参照

TCP

可靠性传输的方式,只是实现不在传输层,实现转移到了应用层,主要通过实现确认机制、重传机制、窗口确认等机制来实现可靠传输,有

RUDP

RTP

UDT

等开源程序利用

UDP

实现了可靠的数据传输,此外有结合

TCP

的可靠与

UDP

速度的权衡

KCP

协议。

TCP短连接和长连接的区别

短连接:

Client

Server

发送消息,

Server

回应

Client

,然后一次读写就完成了,这时候双方任何一个都可以发起

close

操作,不过一般都是

Client

先发起

close

操作。短连接一般只会在

Client/Server

间传递一次读写操作。短链接管理起来比较简单,建立存在的连接都是有用的连接,不需要额外的控制手段,但是如果客户请求频繁,将在

TCP

的建立和关闭操作上浪费时间和带宽。

长连接:

Client

Server

完成一次读写之后,它们之间的连接并不会主动关闭,后续的读写操作会继续使用这个连接,长连接可以省去较多的

TCP

建立和关闭的操作,减少浪费,节约时间,对于频繁请求资源的客户来说,较适用长连接,但是随着客户端连接越来越多,

Server

负载会越来越大,此时就需要采取一些策略减少负载,例如关闭长时间未读写的链接

LRU

算法、限制客户端链接数量等。

TCP粘包拆包解决方案

由于

TCP

本身是面向字节流的,无法理解上层的业务数据,所以在底层是无法保证数据包不被拆分和重组的,这个问题只能通过上层的应用协议栈设计来解决。

  • 消息定长:发送端将每个数据包封装为固定长度(不够的可以通过补 填充),这样接收端每次接收缓冲区中读取固定长度的数据就自然而然的把每个数据包拆分开来。
  • 设置消息边界:服务端从网络流中按消息边界分离出消息内容,在包尾增加回车换行符进行分割,例如

    FTP

    协议。
  • 将消息分为消息头和消息体:消息头中包含表示消息总长度(或者消息体长度)的字段。

参考

https://zhuanlan.zhihu.com/p/108822858
https://www.cnblogs.com/liangyc/p/11628148.html
https://blog.csdn.net/m_xiaoer/article/details/72885418
https://blog.csdn.net/pangyemeng/article/details/50387078
https://blog.csdn.net/quiet_girl/article/details/50599777
https://blog.csdn.net/liuchenxia8/article/details/80428157
https://blog.csdn.net/qq_40732350/article/details/90902396
https://www.cnblogs.com/fundebug/p/differences-of-tcp-and-udp.html           

复制