TCP可靠的传输机制

本文详细解析了TCP提供的一种面向连接的、可靠的字节流服务,包括其工作原理、关键机制以及如何确保数据传输的可靠性。重点阐述了面向字节流和缓存机制、超时重发和确认机制、检验和机制、字节编号机制、主动丢弃重复机制和流量控制等核心概念。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

TCP提供一种面向连接的、可靠的字节流服务。面向连接意味着两个使用TCP的应用(一般是一个客户和一个server)在彼此交换数据包之前必须先建立一个TCP连接。这一过程与打电话非常相似。先拨号振铃,等待对方摘机说“喂”。然后才说明是谁。在一个TCP连接中。仅有双方进行彼此通信。

广播和多播不能用于TCP。

TCP通过下列方式来提供可靠性:
1.面向字节流和缓存机制: 应用数据被切割成TCP觉得最适合发送的数据块。这和UDP全然不同,应用程序产生的数据长度将保持不变。由TCP传递给IP的信息单位称为报文段或段(segment)。
2.超时重发和确认机制: 当TCP发出一个段后,它启动一个定时器,等待目的端确认收到这个报文段。

假设不能及时收到一个确认,将重发这个报文段。

当TCP收到发自TCP连接还有一端的数据,它将发送一个确认。TCP有延迟确认的功能,在此功能没有打开,则是马上确认。功能打开,则由定时器触发确认时间点。

3.检验和机制: TCP将保持它首部和数据的检验和。

这是一个端到端的检验和。目的是检測数据在传输过程中的不论什么变化。

假设收到段的检验和有差错,TCP将丢弃这个报文段和不确认收到此报文段(希望发端超时并重发)。

4.字节编号机制: 既然TCP报文段作为IP数据报来传输。而IP数据报的到达可能会失序。因此TCP报文段的到达也可能会失序。假设必要。TCP将对收到的数据进行又一次排序,将收到的数据以正确的顺序交给应用层。

5.自己主动丢弃反复机制 :既然IP数据报会发生反复。TCP的接收端必须丢弃反复的数据。
6.流量控制: TCP还能提供流量控制。TCP连接的每一方都有固定大小的缓冲空间。TCP的接收端仅仅同意还有一端发送接收端缓冲区所能接纳的数据。

这将防止较快主机致使较慢主机的缓冲区溢出。

两个应用程序通过TCP连接交换8bit字节构成的字节流。TCP不在字节流中插入记录标识符。我们将这称为字节流服务(bytestreamservice)。

假设一方的应用程序先传10字节,又传20字节,再传50字节。连接的还有一方将无法了解发方每次发送了多少字节。

仅仅要自己的接收缓存没有塞满,TCP 接收方将有多少就收多少。一端将字节流放到TCP连接上,相同的字节流将出如今TCP连接的还有一端。

其他,TCP字节流中没有任何解释的内容,无论。TCP我不知道所发送的数据字节的二进制数据流。仍是ASCⅡ字符、EBCDIC字符,或其他类型的数据。

由该字节流的解释TCP连接所述应用层解释的两侧。

转载于:https://www.cnblogs.com/gcczhongduan/p/5028129.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值