网络通信之校验

这是一个可选的选项,并不是所有的系统都对UDP数据包加以检验和数据(相对TCP协议的必须来说),但是RFC中标准要求,发送端应该计算检验和。

  UDP检验和 覆盖UDP协议头和数据,这和IP的检验和是不同的,IP协议的检验和只是覆盖IP数据头,并不覆盖所有的数据。

TCP校验:首部和数据的校验和;

UDP校验:ipv4中首部和数据的校验和,但是是可选的;ipv6必选;

IP校验:首部校验和;

TCP是基于流的;什么是流呢?

UDP是基于数据包;

校验方法:二进制求反码相加即得和;

TCP半关闭;

 Nagle算法:

  由于Tcp中的微小分组(比如:41Byte的分组:20Byte的IP头,20Byte的TCP头和1个Byte的数据)在广域网上回增加拥塞的可能,Nagle算法就是优化该问题的;

该算法要求一个TCP连接上最多只能有一个未被确认的未完成的小分组,在该分组的确认到达之前不能发送其他的小分组;相反,TCP收集这些少量的分组,并在确认到来时以一个分组的方式发出去;

  该算法的优越之处在于它是自适应的:确认到达得越快,数据也就发送的越快;

 tcp的成块数据流:

  正常的数据流通常是采用“隔一个报文确认”的策略;就是说:s端收到报文段1,先不进行ack;而是等到收到报文段2之后,再ack回应客户端;

滑动窗口协议:(窗口的大小是不断变化的; )

  在c端保存,并受s端和c端共同控制;

假设先将待发送的字节编号:1、2、3、4、5、6、7、8、9、0、10、11、12;由三次握手建立连接之后,得到s端的tcp的buf大小即滑动窗口的初始化大小(假设为6Byte);

a:此时滑动窗口的左边沿是:1号,右边沿是:6号;此时发送1、2、3、号之后,滑动窗口位置不变,

b:s端向c端确认ack=4;win=6;此时窗口左边移动到7号处,右边移动到:4+6即10处;

c:接着:第二段报文发送4、5、6、7号,此时窗口不动,因为只有再收到s端的ack之后才改变位置、大小;

d:s端确认第二段报文,ack=8,win=3;说明s端的tcp缓存只有一个byte空间;滑动窗口左边移动到8号处,右边移动到3+8即11号处;

特殊情况:

    1、如果c端收到一个滑动窗口左边沿向左边移动的ack;则认为该ack是一个重复的ack;直接丢弃;(这是因为,滑动窗口的左边是由s端确认收到序号控制,因此不可能向左边移动)

    2、如果左边沿到达右边沿,则称其为一个零窗口,此时发送方不能够发送任何数据;

PUSH标志:

    在每一个tcp例子中,我们都看到了PUSH标志,其用途是c方使用该标志通知s方将所有接收到的数据全部提交给接收进程;这里的数据 包括:与PUSH一起传送的数据以及接收方tcp以及为接收进程接收到的其他数据;

  慢启动:(slow start)

    慢启动为c方tcp增加了另一个窗口:拥塞窗口(congestion  window,简写:cwnd);

  1、当与s端建立tcp连接时,cwnd被初始化为1个报文端;此后没收到一个s端的ack,cwnd就增加一个报文段(cwnd以字节为单位,但是慢启动以报文段大小为单位进行增加);

  2、c端取拥塞窗口与通告窗口中的最小值作为发送上限;

    拥塞窗口是c端式用的流量控制,通过窗口是s端的流量控制;

  具体的内容“创建tcp超时和重传机制”

 

    

 

时间: 2024-09-12 09:16:25

网络通信之校验的相关文章

计算机体系结构(三)——循环冗余校验

    在校验码体系中,有各种校验的方法:有奇偶校验.海明码校验.循环冗余校验.今天就跟大家共同探讨一下常用的循环冗余校验吧.     循环冗余校验(CRC,Cyclic Redundancy Check),是最常用的一种差错校验码,其特征是信息字段和校验字段的长度可以任意选定.已经被广泛应用于网络通信即磁盘存储.     多项式:一个二进制数可以用一个多项式来表示,如1011 表示为 x3+x1+x0 .最高次幂n,可以转为长度为n+1的二进制数.     CRC编码组成:在K位信息码后再拼接

《Ceph源码分析》——第3章,第1节Ceph网络通信框架

第3章Ceph网络通信本章介绍Ceph网络通信模块,这是客户端和服务器通信的底层模块,用来在客户端和服务器之间接收和发送请求.其实现功能比较清晰,是一个相对较独立的模块,理解起来比较容易,所以首先介绍它. 3.1 Ceph网络通信框架一个分布式存储系统需要一个稳定的底层网络通信模块,用于各节点之间的互联互通.对于一个网络通信系统,要求如下:高性能.性能评价的两个指标:带宽和延迟.稳定可靠.数据不丢包,在网络中断时,实现重连等异常处理.网络通信模块的实现在源代码src/msg的目录下,其首先定义了

身份证校验,检查身份证号码输入是否正确

Netkiller MySQL 手札 MySQL MariaDB... Mr. Neo Chan, 陈景峰(BG7NYT) 中国广东省深圳市龙华新区民治街道溪山美地518131+86 13113668890+86 755 29812080<netkiller@msn.com> 文档始创于2010-11-18 版权 2011, 2012, 2013 Netkiller(Neo Chan). All rights reserved. 版权声明 转载请与作者联系,转载时请务必标明文章原始出处和作者信

巧用SQL-DMO创建备份及校验的ASP应用

sql|备份|创建 概述 SQL分布式管理对象(SQL Distributed Management objects, SQL-DMO)为开发者提供了使用程序和脚本语言执行普通任务的方法,从而扩展了SQL Server功能.本文谈论如何巧妙的利用SQL-DMO创建数据库备份和校验的ASP应用. 前提 你需要有SQL Server数据库备份的相关知识.另外还要在global.asa文件中加入SQL-DMO库的引用.以下是SQL Server 2000的引用: <!--METADATA TYPE=&qu

md5校验工具怎么用?

  第一步:打开MD5校验工具 第二步:将您下载的软件拖到该软件内 第三步: 将您MD5软件生成的校验码与我们官网上公布的校验码做对比. 相同则表示您所下载的软件为合法软件.不同则表示您所下载的软件已被非法改动,请不要安装使用

文本框内容拆解获取里面的值进行校验

问题描述 文本框内容拆解获取里面的值进行校验 从页面的文本框中获取对应的VO,但是VO的值是如:a,b,c有逗号相隔,问题是如何才能对拆解这个值获取里面的每个值进行校验 解决方案 用split函数,很多编程语言都支持这个函数,但是调用略有差别,你google下. 解决方案二: split或者用正则验证下

JS验证身份证号地区码及最后一位校验码

/* 参数为身份证号 返回正确校验码 */ function getjy(id) {     var arr = new Array();//分别取出身份证的前17位加入到这个数组     var arr1 = new Array();//对向相应的次方     var num = 0;     for (var i = 0; i < 17; i++) {         arr[i] = id.charAt(i);     }     for (var i = 0; i < arr.leng

Flink运行时之基于Netty的网络通信(下)

客户端核心处理器 这一篇,我们分析一下客户端协议栈中的核心的处理器PartitionRequestClientHandler,该处理器用于处理服务端的响应消息. 我们以客户端获取到响应之后回调该处理器的channelRead方法为入口来进行分析: public void channelRead(ChannelHandlerContext ctx, Object msg) throws Exception { try { //当没有待解析的原始消息时,直接解码消息,否则将消息加入到stagedMe

关于js校验

关于js校验 判断字符传是否符合如下格式: 111,222,333,444 逗号分割的数字组合 主要有两个小函数: <script> function isIntNumber(num) { var type="^[0-9]*[1-9][0-9]*$"; var re = new RegExp(type); if(num.match(re)==null) { return false; } else { return true; } } function isOK(uids)