三次握手协议:三次握手协议的主要过程是交互彼此之间的初始序列号,如果没有确认的ACK帧可以么?肯定是可以的

client A -------> server B

client A 发送了自己的初始序列号;然后B看见了之后B发送了一个初始序列号,这样两次“握手”都可以啊。但是两次握手的问题是:此时A开始发送信息,B肯定是收到了A的序列号了;B告诉A说我的序列号;二次握手基于的假设是:我发送结束后默认你已经知道了我的初始序列号是多少,但是现在的问题是B肯定是知道A的序列号了,所以B可以很自如地向A发送数据包,但是如果A一直没有发送数据包,那么是因为B的sync序列号的包没有达到,A不知道B的初始序列号所以没发呢?还是说A就是没有发送数据包,还是说A的数据包丢失了呢?B端充满了疑惑。好像是可以工作的,B端此时会超时重传,不断地去发送SYNC包告诉A说自己的初始序列号;那么这里就是整个问题的核心了:此时我如果A就是没有数据要发呢? 你B一遍遍给我发初始的序列号信息,1个,2个,3个,。。。。,此时A可以告诉你说序列号包我收到啦,别发了再(这不就是第三次握手的内容么)。。。所以,如果是两次握手的话,B的回复包没丢还好,如果丢了,那么至少还要发送两个数据包来确认问题!这是至少!因此还是要通过三次握手才行呢;三次握手,A和B都能达到一个终态,这个终态可以有效防止丢包的雪崩效应。如果B一直没有收到A的ack帧,那么就重发syncB,acka;如果A一直没有收到B的syncB,ackA,那么就重新发ackA;三次握手的一个最大的好处就是告诉B:A知道你的初始序列号是多少了,可能暂时不会有数据过来了,所以疑惑扫了一大堆。到这里其实建立的是A和B的全双工的链路。

那四次挥手又是解决啥问题呢?

A调用close是为了说啥呢?是说我这里不在对你B发送数据,还是告诉B我不再接受数据呢?是前者,告诉B我不再向你发送数据了(但是我这边仍然有段时间会接受到你的数据)或者说是申请关闭链接,你看着办吧。

ACK报文在TCP协议中超级重要,它可以很大程度防止丢包引起的重传。握手阶段的ACK上面已经分析过了;在真正的数据传输阶段呢,当A发送了1,2,3,4,5包,然后又发送了6,我怎么确定包是否是收到了呢?要不然我一个劲儿地发也没用呀,ACK帧的主要作用就是让A和B的信息透明。

ACK在整个TCP协议中的作用是信息透明,防止重传;

在结束的时候也是这样,如果A发送了FIN,如果好久没有相应,那么A怎么知道到底是因为数据包在A->B的路上丢了,还是B已经收到了,所以必须要让A心知肚明,此时B先发送一个ACK帧过来,通知A:我B收到了你的断开请求。【还是没有找到问题的根源。三次握手的第三个ACK包是为了降低B的疑惑,即当A迟迟没有发数据,不是因为A没有收到B的序列号,而是Abenlai

TCP的挥手协议和握手协议2的更多相关文章

  1. TCP/IP的三次握手协议

    关于TCP/IP的三次握手协议,这篇文章中有详细的介绍,很通俗易懂,什么时候忘了,都可以过来瞧两眼,保证很快就明白了. 首先TCP/IP协议分为三个阶段:建立连接(握手阶段),数据传输阶段,连接终止阶 ...

  2. TCP的挥手协议和握手协议

    三次握手协议:三次握手协议的主要过程是交互彼此之间的初始序列号,如果没有确认的ACK帧可以么?肯定是可以的 client A -------> server B client A 发送了自己的初 ...

  3. 最简单的理解 建立TCP连接 三次握手协议

     最简单的理解一:建立TCP连接:三次握手协议    客户端:我要对你讲话,你能听到吗:服务端:我能听到:而且我也要对你讲话,你能听到吗:客户端:我也能听到.…….互相开始通话…….. 二:关闭TCP ...

  4. SSL 握手协议详解

    这里重点介绍一下服务端的验证和密钥交换.这个阶段的前面的(a)证书 和(b)服务器密钥交换是基于密钥交换方法的.而在SSL中密钥交换算法有6种:无效(没有密钥交换).RSA.匿名Diffie-Hell ...

  5. SSL协议(HTTPS) 握手、工作流程详解(双向HTTPS流程)

    原文地址:http://www.cnblogs.com/jifeng/archive/2010/11/30/1891779.html SSL协议的工作流程: 服务器认证阶段:1)客户端向服务器发送一个 ...

  6. SSL协议的握手过程(摘录)

    SSL协议的握手过程 为了便于更好的认识和理解 SSL 协议,这里着重介绍 SSL 协议的握手协议.SSL 协议既用到了公钥加密技术(非对称加密)又用到了对称加密技术,SSL对传输内容的加密是采用的对 ...

  7. 【转】SSL协议、SET协议、HTTPS简介

    一.SSL协议简介 SSL是Secure Socket Layer的缩写,中文名为安全套接层协议层.使用该协议后,您提交的所有数据会首先加密后,再提交到网易邮箱,从而可以有效防止黑客盗取您的用户名.密 ...

  8. 软件开发架构介绍||OSI七层协议之物理层、数据链路层、网络层、传输层(mac地址、ip协议、断开协议、tcp协议之三次握手四次挥手)

    一.网络编程 软件开发架构 C/S架构 C:客户端 想体验服务的时候才会去找服务端体验服务 S:服务端   24小时不间断的提供服务,即时监听,随时待命 B/S架构 B:浏览器    想体验服务的时候 ...

  9. TCP连接三次握手协议,释放连接四次挥手,以及使用 awl伪造mac地址进行多线程syn洪泛攻击。

    这个TCP连接就是一次追女生-谈恋爱-分手,追求比分手简单,但是分手比追求复杂.哥,谈了半年的女朋友,在就快要成功了的时候分了,原因是因为有人在后面该老子背后搞SYN洪泛攻击,最后女朋友丢失了.学会T ...

随机推荐

  1. C++指针数组,二级指针和函数指针的练习

    1.编一程序,将字符串“Hello,C++!”赋给一个字符数组, 然后从第一个字母开始间隔地输出该串(请用指针完成). 代码如下 #include<iostream> #include&l ...

  2. 利用login-path对MySQL安全加固

      Preface       Connection security is  one of the most important safety strategies which we should ...

  3. keil5 mdk使用ST-Link II下载出现cannot halt the core解决办法

    在正常的程序里面,我添加了MB85RS16(spi flash)这个外设驱动代码后,使用ST-Link II下载就出现cannot halt the core. 这个现象之前出现过1次,但是解决办法忘 ...

  4. 中国农产品信息网站scrapy-redis分布式爬取数据

    ---恢复内容开始--- 基于scrapy_redis和mongodb的分布式爬虫 项目需求: 1:自动抓取每一个农产品的详细数据 2:对抓取的数据进行存储 第一步: 创建scrapy项目 创建爬虫文 ...

  5. QOS-基本拥塞管理机制(PQ CQ WFQ RTPQ)

    QOS-基本拥塞管理机制(PQ CQ WFQ RTPQ) 2018年7月7日    20:29 拥塞:是指当前供给资源相对于正常转发处理需要资源的不足,从而导致服务质量下降的一种现象 拥塞管理概述: ...

  6. uva 540 - Team Queue(插队队列)

    首发:https://mp.csdn.net/mdeditor/80294426 例题5-6 团体队列(Team Queue,UVa540) 有t个团队的人正在排一个长队.每次新来一个人时,如果他有队 ...

  7. ABS(引数と同じ大きさの正の数を返す)

    ABS 関数 [数値] 数値式の絶対値を返します. 構文 ABS( numeric-expression ) パラメータ numeric-expression   絶対値が返される数値. 戻り値 数値 ...

  8. P1189 SEARCH(逃跑的拉尔夫)

    P1189 SEARCH 题目描述 年轻的拉尔夫开玩笑地从一个小镇上偷走了一辆车,但他没想到的是那辆车属于警察局,并且车上装有用于发射车子移动路线的装置. 那个装置太旧了,以至于只能发射关于那辆车的移 ...

  9. 不用找了,比较全的signalR例子已经为你准备好了(2)---JqGrid 服务端刷新方式-注释详细-DEMO源码下载

    上次用客户端进行数据刷新的方式,和官方的Demo实现存在差异性,今天花了一点时间好好研究了一下后台时时刷新的方式.将写的代码重新update了一次,在这之前找过好多的资料,发现都没有找到好的例子,自己 ...

  10. 用链表实现nodejs的内存对象管理

    虽然javascript拥有垃圾收集,但是垃圾收集机制并不会自动释放持久对象,比如websocks连接. 为了能够在某些特定情况下中止一些连接(比如内存不足),显然要建立全局的对象管理器进行管理. 显 ...