通行导论-IP数据网络基础(2)
传输控制协议(TCP)
差错控制:TCP使用差错控制提供可靠性,包括检测受到损伤、丢失、失序的报文段
实现方法:1.16位检验和,2.确认机制:采用确认证实收到的报文段,3.重传(设置一个重传超时RTO计时器,计时器时间到,认为对应报文段丢失;收到3个重复的ACK立即重传丢失报文段,即快重传;对不消耗序号的报文段不重传)
特点:控制报文段不携带数据,但消耗一个序号;控制报文段也需要被确认;ACK报文段不消耗序号,也不需要确认
拥塞控制:网络中的负载大于容量就可能发生拥塞;通过窗口机制(流量控制)决定发送或接收端能够发送的最大数据量
拥塞窗口:发送端根据自己估计的网络拥塞程度而设置的窗口值(来自发送端的流量控制),接收端窗口:接收端根据目前的接受缓存大小所许诺的最新的窗口值(来自接收端的流量控制)
拥塞猜测:依靠重传发生猜测拥塞发生(慢开始、加速递减和拥塞避免算法)
- 发生超时
- 执行慢开始算法,拥塞窗口初始值为1,发送第一个报文段M0;发送端收到ACK1(确认M0,期望收到M1)后,将cwnd从1增加到2,于是发送端可以接着发送M1和M2两个报文段;接收端发回ACK2和ACK3,发送端每收到一个队新报文段的确认ACK,发送端的拥塞窗口加1,现在cwnd从2增到4,并发送M4~M8共4个报文段(即拥塞窗口cwnd随着传输次数按指数规律增长)
- 当拥塞窗口cwnd增长到慢开始门限值ssthresh(即当cwnd=16)时,改为执行拥塞避免算法,拥塞窗口按线性规律增长
- 利用TCP重传计时器设置拥塞窗口数值增长到24时,网络出现超时(表明网络拥塞了)
- 更新后的ssthresh变为12(即变为发送窗口值24的一半),拥塞窗口再重新设置为1,并执行慢开始算法
- 当cwnd=12时改为执行拥塞避免算法,拥塞窗口按线性规律增长,每经过一个往返时延就增加一个MMS的大小(?)
- 收到3个ACK:发生超时前cwnd的变化与发生超时时一样,发生超时后更新后的ssthresh变为12(即变为发送窗口值24的一半),拥塞窗口的值直接变为与ssthresh相同的值(发生超时与进入拥塞避免相连),之后一样执行拥塞避免算法,拥塞窗口按线性规律增长
传输层协议(UDP)-不可靠,面向无连接,高效
UDP用户数据报的首部格式
伪首部:计算检验和是,临时把伪首部和UDP用户数据报连接在一起,伪首部仅仅是为了计算检验和(12字节)
TCP与UDP的区别
TCP | UDP | |
是否面向连接 | 面向连接 | 无连接 |
是否提包可靠性 | 可靠传输 | 不提供可靠性 |
是否流量控制 | 流量控制 | 不提供流量控制 |
传输速度 | 慢 | 快 |
协议开销 | 大(20字节) | 小(8字节) |
网络层协议(IP)
首部长度字段:占4位,以4字节(32bit)为单位(不以字节为单位)
总长度字段:占16位,单位为字节;首部长度(即4*HLEN)+数据长度;总长度必需不超过最大传送单元MTU;IP分组的最大长度是65535
标识字段:源站每发送一个分组,标识位加1;(源IP地址,标识)→全网唯一分组标识--标识同一数据报的各个分片
标志字段:占3位,最低位为MF(More Fragment),用一比特位来表示“更多的片”,MF=0最后一个分片,MF=1不是最后一个分片;中间一位是DF(Don't Fragment)只有等于0时才允许分片
D | M |
片偏移字段:8字节为偏移单位--分片的顺序
生存时间(TTL):源和目的之间的路由器个数(跳数);最大值为255(20+21+……28);路由器转发时TTL减1,为0时丢弃该分组
首部检验和:若接收端利用发送端的检验和计算出的结果为0则保留,否则丢弃该数据报
分片计算片偏移字段的值为每个分片的第一个数据/8,普通包头部长度为20字节(MTU-20)
若某分片丢失,则丢弃所有分片,重传整个数据报
2019-03-11 星期一
通行导论-IP数据网络基础(2)的更多相关文章
- 通信导论-IP数据网络基础(4)
IP地址的编址方法--IP地址+掩码地址=网络地址 分类的IP地址 每一类地址都由两个固定长度的字段组成,其中一个字段是网络号 net-id,标志主机或路由器所连接到的网络,另一个字段则是主机号 ho ...
- 通信导论-IP数据网络基础(1)
TCP/IP封装过程: 端口号:服务器一般都是通过知名端口号(1~1023)来识别应用程序,(TCP)21.23.25,(UDP)53.69.161 TCP报文格式: 字节号:TCP把连接中发送的所有 ...
- 通信导论-IP数据网络基础(3)
ICMP(IP辅助协议)--网际控制报文协议 ICMP报文种类:ICMP差错报文(终点不可达.时间超过等5种)和ICMP询问报文(回送请求和回答请求.时间戳请求和回答报文2种) ICMP是一种集差错报 ...
- 图解TCP/IP笔记-网络基础知识
1.计算机网络发展的7个阶段1)批处理服务器一次只能处理一批程序指令2)分时服务器可以分时为多台客户端服务3)计算机之间通信计算机之间由通信线路连接,互相通信4)计算机网络的产生通过分组交换技术,在不 ...
- TCP/IP通信网络基础
TCP/IP是互联网相关的各类协议族的总称. TCP/IP的分层管理 分层的优点:如果只有一个协议在互联网上统筹,某个地方修改就要把所有的部分整体换掉,采用分层则只需要改变相应的层.把各个接口部分规划 ...
- TCP/IP协议栈---网络基础篇(3)
TCP/IP协议栈 在网络中实际使用的是TCP/IP,OSI是参考模型. TCP/IP协议栈 – 是由一组不同功能的协议组合在一起构成的协议栈 – 利用一组协议完成OSI所实现的功能 应用层协议 传输 ...
- 网络基础知识-TCP/IP协议各层详解
TCP/IP简介 虽然大家现在对互联网很熟悉,但是计算机网络的出现比互联网要早很多. 计算机为了联网,就必须规定通信协议,早期的计算机网络,都是由各厂商自己规定一套协议,IBM.Apple和Micro ...
- 【Windows socket+IP+UDP+TCP】网络基础
Windows Socket+网络 Winsock是 Windows下套接字标准. Winsock 编程分为UDP[Windows socket + UDP],TCP[Wi ...
- 【Linux网络基础】网络拓扑、OSI层次模型、TCP/IP协议簇
一.前言 一个运维有时也要和网络打交道,所以具备最基本的网络知识,对一个运维人员来说是必要的.但,对于我们的工作来说这些并不是重点,因此,我不可能从最基础的网络知识开始讲起.本节内容更多是从一个梳理和 ...
随机推荐
- Kubernetes及Dashboard详细安装配置(Ubuntu14.04)
前些日子部门计划搞并行开发,需要对开发及测试环境进行隔离,所以打算用kubernetes对docker容器进行版本管理,搭建了下Kubernetes集群,过程如下: 本流程使用了阿里云加速器,配置流程 ...
- To be taught if i am fortunate
此博客算是我自娱自乐的海洋球池吧. 由于我十分的菜并且文笔拙劣,所以您可能并不能在这找到什么有用的信息或者好玩的东西(或者exciting的内容). 如果您能指出我的一些错误,我将十分感激.
- Java 中 Equals和==的区别(转)
另外一篇参考: https://blog.csdn.net/striverli/article/details/52997927 在谈论equals和==的区别前,我们先简单介绍一下JVM中内存分配的 ...
- C语言数据结构基础学习笔记——B树
2-3树:是一种多路查找树,包含2结点和3结点两种结点,其所有叶子结点都在同一层次. 2结点:包含一个关键字和两个孩子(或没有孩子),其左孩子的值小于该结点,右孩子的值大于该结点. 3结点:包含两个关 ...
- jquery中文档处理的总结
jQuery文档处理总结 1.返回值:append(content|fn) $("p").append("<b>Hello</b>"); ...
- django Table doesn't exist
1146 django Table '' doesn't exist 一:出错原因 手动在数据库中drop了一张表,重新执行python manage.py migrate时出错,提示不存在这 ...
- Python Excel 多sheet 多条数据 自定义写入
pip install xlwt python excel 数据写入操作,处理网站数据导出以及不是太多数据的爬虫存储, 用处蛮多的轮子. (150+++++++++++++++++++++++++++ ...
- zk hdfs hadoop yarn hive 学习笔记
如图
- 分布式 基本理论 CAP 2
关于P P, 即 Partition字面意思是网络分区,其实 包括了 各种网络问题, 我们要把它理解 一个 广义的 分区问题. P 涉及到了 时间, 这么说吧, 出现了分区, 那就是节点之间 “长久的 ...
- tornado架构分析3 options.py中基础类_Option
1 数据清洗 option里面最重要的方法就是parse,在这里,parse函数的一开始就调用了后面的子函数_parse_datetime,_parse_timedelta,_parse_bool,_ ...