TCP 是如何实现可靠传输的

本文目的

本文主要是 区分技术依赖 并将一些技术简单介绍一下,不会涉及到具体技术讲解。如果有一些网络经验,本文可以做一些比较;如果是网络小白,可以把本文当做是目录。

TCP是如何实现可靠传输的?说到这个问题,我们可能会迸出 TCP 的一系列特点。数据分片和排序、校验和、确认应答和序列号、超时重传、连接管理、流量控制、拥塞控制、滑动窗口等等。其实这里的技术应该是分为两类的,可靠传输和高效传输。并不是所有的技术都是可靠传输的依赖。

可靠传输主要依赖:数据分片、序列号和确认应答、校验和、超时重传。
高效传输主要依赖:流量控制、拥塞控制、滑动窗口。

名词简介

  • 数据分块:应用数据被分割成 TCP 认为最适合发送的数据块。
  • 序列号和确认应答:TCP 给发送的每一个包进行编号,在传输的过程中,每次接收方收到数据后,都会对传输方进行确认应答,即发送 ACK 报文,这个 ACK 报文当中带有对应的确认序列号,告诉发送方成功接收了哪些数据以及下一次的数据从哪里开始发。除此之外,接收方可以根据序列号对数据包进行排序,把有序数据传送给应用层,并丢弃重复的数据。
  • 校验和:TCP 将保持它首部和数据部分的检验和。这是一个端到端的检验和,目的是检测数据在传输过程中的任何变化。如果收到报文段的检验和有差错,TCP 将丢弃这个报文段并且不确认收到此报文段。
  • 流量控制:TCP 连接的双方都有一个固定大小的缓冲空间,发送方发送的数据量不能超过接收端缓冲区的大小。当接收方来不及处理发送方的数据,会提示发送方降低发送的速率,防止产生丢包。TCP 通过滑动窗口协议来支持流量控制机制。
  • 拥塞控制:当网络某个节点发生拥塞时,减少数据的发送。涉及到四种算法:慢开始、拥塞避免、快恢复、快重传。这里不详细介绍。
  • ARQ协议:也是为了实现可靠传输的,它的基本原理就是每发完一个分组就停止发送,等待对方确认。在收到确认后再发下一个分组。
  • 超时重传:当 TCP 发出一个报文段后,它启动一个定时器,等待目的端确认收到这个报文段。如果超过某个时间还没有收到确认,将重发这个报文段。

TCP 实现可靠传输 是面试的热题,面经也只是个人对于相关知识的理解,是有局限的,扎实的基础还是需要静下心来仔细学习的,系个人笔记。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值