TCP-IP详解笔记8
TCP-IP详解笔记8
TCP超时与重传
- 下层网络层(IP)可能出现丢失, 重复或丢失包的情况, TCP协议提供了可靠的数据传输服务.
- TCP启动重传操作, 重传尚未确定的数据.
- 基于时间重传.
- 基于确认信息. --- 比较高效.
- TCP在发送数据时会设置一个计时器, 若计时器超时仍未收到数据确认信息, 则会引起相应的超时或基于计时器的重传操作, 计时器超时称为重传超时(RTO).
- 快速重传推断出丢包.
- 经典方法:
- 平滑的RTT估计值. (加权移动平均, 低通滤波器)
- RTO超时重传时间.
- 快速重传机制基于接收端的反馈信息来引发重传, 而非重传计时器的超时.
- TCP接收端可提供SACK功能, 通过TCP头部积累的ACK号字段来描述其接收到的数据.
TCP数据流与窗口管理
- TCP的动态数据传输, 交互连接, 流量控制, 窗口管理.
- 流量控制通过动态调节窗口大小来控制发送端的操作, 确保接收端不会溢出.
- 延迟确认可以允许TCP延迟一段时间发送ACK, 以便将ACK和相同方向上需要传输的数据结合发送.
- 可以减少ACK传输数目, 可以一定程度地减轻网络负载.
- Nagle算法:
- 当一个TCP连接中有在传输数据, 小的报文段就不能被发送, 直到所有的在传输数据都被ACK.
- 采用滑动窗口来实现流量控制.
- 每个TCP活动连接的两端都维护一个发送窗口结构(send window)和接收窗口结构(receive window structure).
- TCP是通过接收端的通告窗口来实现流量控制的, 通告窗口指示了接收端可接收的数据量. 接收端会传输一个窗口更需你(window update).
TCP 拥塞控制
- TCP拥塞控制是批量数据中最重要的. 防止网络因为大规模的数据通信而瘫痪.
- 路由去因无法处理高速率到达的流量而被迫丢弃数据信息的现象称为拥塞.
- 没有一个精准的方法知晓中间路由器的状态.
- 在TCP中丢包被用作判断是否拥塞的一个指标, 用来衡量是否实施相应的响应措施.
- 延时测量和显示拥塞通知(ECN).
- 减缓TCP发送, 慢启动.
- 当一个新的TCP连接建立或检测到由重传超时(RTO)导致的丢包时, 需要执行慢启动.
- TCP发送端长时间处于空闲状态也可能调用慢启动算法.
- 拥塞避免:
- TCP实现了拥塞避免算法, 一旦确定慢启动阈值, TCP会进入拥塞避免阶段, cwnd每次的增长值近似于成功传输的数据段大小.
- 拥塞避免算法假设由比特错误导致包丢失的概率很小(远小于1%), 因此有丢包发生就表明从源端到目的端必有某处出现了拥塞.
- TCP连接时是选择运行慢启动和拥塞避免中的一个, 不会出现两个同时出现的情况.
TCP保活机制
- 在一个空闲的TCP连接中不会有任何数据交换.
- TCP保活机制为了让客户端和服务器了解什么时候终止进程或者对方断开连接, 虽然连接没有数据交换,但仍然需要通过连接保持一个最小的数据流.
- 它是由一个保活计时器实现的, 当计时器被激发, 连接一段将发送一个报货探测(简称保活)报文, 另一端接收报文的同时会发送一个ACK作为响应.
- 保活功能一般是为服务器应用程序提供的, 服务器应用程序希望知道客户机是否崩溃或离开, 从而决定是否为客户端绑定资源.
- 当某个连接长时间(2小时)处于空闲状态, 在该连接的一端会发送一个探测数据包, 从而实现保活功能, 可能有4种情况:
- 另一端仍在工作;
- 另一端崩溃;
- 另一端已经崩溃并且已经重新启动;
- 另一端无法到达.
TCP-IP详解笔记8的更多相关文章
- TCP/IP详解 笔记十四
TCP/IP协议(二) 连接的建立与终止 tcpdump -S输出TCP报文的格式 格式: 源>目的:标志 (标志就是tcp头部).标识首字符意义如下: 例如:telnet 某服务的输出(包括 ...
- TCP/IP详解 笔记一
概述: Tcp-ip让网络上的计算机进行通信,而不管计算机和操作系统是否一样. 分层结构: Tcp/ip协议族是多层协议的组合,而tcp和ip只是其中的两个协议而已. 一个通信举例: 注意图的右上方: ...
- TCP/IP详解 笔记十三
TCP协议(一) 概述 特点 1, 面向连接可靠的字节流服务 2, 只有两方通信,不能用于广播或多播 3, 应用数据被TCP分隔为最合适发送的数据段,传给IP协议栈 4, 发送端并启动定时器, ...
- TCP/IP详解 笔记十一
域名服务系统(DNS) DNS:名字到IP转换:电子邮件选路信息:分布式数据库 解析器:是通过gethostbyname(3)和gethostbyaddr(3)来实现的 最常用的名字服务器是BIND ...
- TCP/IP详解 笔记九
广播和多播 多播和广播只能用于UDP包,TCP明确在两个进程间建立连接. 多播:帧只传送给属于多播组的多个接口 主机对帧的过滤过程: 通常网卡只接收那些目的地址为本物理接口地址或广播地址的帧:设置为混 ...
- TCP/IP详解 笔记八
UDP协议 UDP是传输层协议,提供无连接不可靠的数据传输,其优点失效率高,确定确定是无序不可靠. 报文格式 UDP头部 TCP和UDP的端口号是独立的 UDP长度是指UDP数据报的总长度 UDP的校 ...
- TCP/IP 详解笔记
最早的 TCP 协议文档是 RFC793. TCP 提供一种面向连接的.可靠的字节流服务. 面向连接容易理解,那么什么是字节流服务呢? 答:两个应用程序通过 TCP 连接交换 8 bit 字节构成的字 ...
- TCP/IP详解 笔记十二
简单文件传送协议 TFTP 1) 初衷是为了引导无盘系统 2) 使用UDP 3) 代码都能适合只读存储器 无盘主机通过RARP获得ip地址后进行一个TF ...
- TCP/IP详解 笔记十
IGMP Internet组管理协议 IGMP的作用:让一个物理网络上的所有系统知道主机所在的多播组: 让路由器知道多播数据报应该向哪个端口转发. IGMP有固定长度,没有可选数据,在ip头部的协议值 ...
- TCP/IP详解学习笔记
TCP/IP详解学习笔记(1)-基本概念 TCP/IP详解学习笔记(2)-数据链路层 TCP/IP详解学习笔记(3)-IP协议,ARP协议,RARP协议 TCP/IP详解学习笔记(4)-ICMP协议, ...
随机推荐
- Arguments Optional 计算两个参数之和的 function
创建一个计算两个参数之和的 function.如果只有一个参数,则返回一个 function,该 function 请求一个参数然后返回求和的结果. 例如,add(2, 3) 应该返回 5,而 add ...
- C# NetStream
标题:NetStream 关注点:Read.Write 正文: int size = Read(buf, 0, buf.length); 这里一次会读入length个字节,如果小于这个数量,后面的就是 ...
- Pyhon进阶9---类的继承
类的继承 基本概念 定义 格式如下 继承中的访问控制 class Animal: __CNOUT = 0 HEIGHT = 0 def __init__(self,age,weight,height) ...
- tensorflow-RNN和LSTM
本章主要介绍循环神经网络(recurrent neuralnetwork,RNN)和长短时记忆网络(long short-term memory,LSTM) 一. RNN简介 1.背景 循环神经网络挖 ...
- C博客作业01--分支、顺序结构
1.本章学习总结 1.1 思维导图 1.2 本章学习体会及代码量学习体会 1.2.1 学习体会 在暑假已经有初步接触c语言,所以在学习c语言的开始会比较轻松,但仍然解题时候步骤太过于繁琐,简单的题目复 ...
- hdu-4635(tarjan缩点)
题意:先给你一个n个点,m条边的有向图,问你最多能够增加多少条边,使得这个图不是一个强连通图 解题思路:考虑最多要添加的边数,所以如果能把初始图划分成两个部分,每个部分都是完全图,这两个部分分别用单向 ...
- python——redis
redis简介 redis是一个key-value存储系统.和Memcached类似,它支持存储的value类型相对更多,包括string(字符串).list(链表).set(集合).zset(sor ...
- ADC采样工作原理详解
如何利用单片机的ADC模块(或者独立的ADC芯片)得到接入ADC管脚上的实际电压值?这个问题,是第一次接触ADC时候,大家都会遇到的问题.会读到什么值单片机会读到什么值?需要看一个特性,就是几位的AD ...
- 什么是GPIO?
”通用输入/输出口”(GPIO)是一个灵活的由软件控制的数字信号.他们可由多种芯片提供,且对于从事嵌入式和定制硬件的Linux开发者来说是比较熟 悉.每个GPIO都代表一个连接到特定引脚或球栅阵列(B ...
- MySQL基于GTIDs的MySQL Replication
MySQL M-S GTID 基于GTIDs的MySQL Replication 什么是GTIDs以及有什么特定? 1.GTIDs(Global transaction identifiers)全局事 ...