首页 > 其他分享 >抓包整理————tcp 三次握手[九]

抓包整理————tcp 三次握手[九]

时间:2022-11-13 10:00:49浏览次数:37  
标签:ack 握手 syn tcp sync 发送 然后 抓包

前言

简单抓包一下3次握手。

正文

握手的目标:

  1. 同步sequence 序列化

初始化序列化ISN(Initial Sequence Number)

  1. 交换tcp 通信参数

如MSS、窗口比例因子、选择性确认、指定校验和算法。这个后面讲。

简单的在linux 抓取一下:

这里面就是确认机制哈:

这上面标识说一下哈:s 就是syn的意思,然后这个.就是ack的意思。

然后这里有一个s.标识发送 syn 加 ack,所以不要认为一个包就是一个意思哈,可能包含几种意思,一般来说是两种。

为什么两边的seq 不一样呢?且他们为什么不从0开始呢?

这是因为网络中报文会延迟会重发也可能丢失造成的影响。(后面补系列会这个问题)

SYN:同步序列编号(Synchronize Sequence Numbers)。

握手的第一个报文:

握手的第二个报文:

第三次握手:

演示一下哈,给大家抓个包助助兴。

看这个我们的发起端口是61110,然后对方的目的端口是80。

发起这个握手请求。

然后看下被连接方在干啥。

然后连接方又发了一个ack过去:

这里看到一般发syn的时候一般有一个叫做options的,这个后面跟滑动窗口有关。

状态变迁:

这里说一下状态哈,大概连接的时候有下面几个状态:

  1. closed
  2. listen
  3. syn-sent
  4. syn-received
  5. established

比如a 是客户端,b是服务端。

a 一开始是closed 状态,然后b是listen状态。

然后a主动发送sync,然后就变成了syn-send,b收到就变成了syn-received.

当a 收到sync+ack 就变成了established状态,b发送ack后也变成了established 状态。

这里讲一下syn洪流攻击的原理哈。

上面看到这个图,就是一直发送syn,然后对方就要发送给我syn+ack,但是我不回。

这样对方就要重新发,一直保持这个状态,或者超时。就是操作系统回这个syn+ack 是在一个队列里面,如果排队很长,自然就慢了。

这里想解释一下为什么3次握手的时候,为什么ack要加一,或者说为什么要消费掉一个序列号。

很多人解释是是因为发送方包含了SYN标志位或FIN标志位,认为标志位也是一种数据,但我感觉还是没有解释为什么要这么做。

假设a发送了一个sync包0为b,但是没有响应,然后又发了一个,b回了一个ack 为0 加他的sync假设是1000吧,这意味着下次a发送的还应该是0.

然后a 发送ack为1000给b,这个时候。这个时候第一个没有响应的包到了,那么这个时候b就不确认a的包,到底是想重新连接呢?还是说这是网络延迟包可以丢弃呢。

总之呢,就是为什么有序列号这个东西,就是为了让双方沟通起来是顺序的。

大概是整理了一下3次握手,下一节如何优化3次握手过程。

标签:ack,握手,syn,tcp,sync,发送,然后,抓包
From: https://www.cnblogs.com/aoximin/p/16182281.html

相关文章

  • TCP Connection Status
    ATCPconnectionprogressesthroughaseriesofstatesduringitslifetime.ThefollowingdiagramillustratesthepossiblestatesforaTCPconnectionandhow......
  • TCP-可靠传输-流量-拥塞控制
    1.TCP的可靠传输1.1停止等待ARQ协议主机采用TCP发出信息时会设置一个定时器,若超出定时器所设定的时间还没有响应过来,则主机会认为发出去的消息没有传达到目的......
  • Android TCP客户端
    文章目录​​一、创建工程​​​​二、添加网络权限​​​​三、添加布局代码​​​​四、添加逻辑代码​​​​五、通信测试​​​​六、源码分享​​一、创建工程二、添加......
  • go错误汇总2:[ERROR] listen tcp: address 8082: missing port in address
    go错误汇总2:[ERROR]listentcp:address8082:missingportinaddress错误信息:[ERROR]listentcp:address8082:missingportinaddress 错误原因:代......
  • 【lwip】12-一文解决TCP原理
    目录前言12.1TCP协议简介12.2TCP相关的一些概念词12.2.1MSL12.2.2MSS12.3TCP工作特性12.3.1面向连接12.3.2全双工通信12.3.3可靠性12.3.4缓冲机制12.3.5拥塞控制......
  • 关于单机最大tcp连接数 及 linux …
    在tcp应用中,server事先在某个固定端口监听,client主动发起连接,经过三路握手后建立tcp连接。那么对单机,其最大并发tcp连接数是多少?如何标识一个TCP连接ip, local port,remo......
  • TCP 三次握手-四次挥手
    TCP三次握手传输控制协议(TCP,TransmissionControlProtocol)是一种面向连接的、可靠的、基于字节流的传输层通信协议,由IETF的RFC793[1]定义。TCP三次握手是TCP建立连接......
  • TCP三次握手一二三问
    下面整理下TCP握手和挥手的几个问题,参考资料小林图解计算机网络1、什么是三次握手?Client端向Server端发送SYN为1的报文段,携带一个初始序列号x,client端进入SYN_SENT状态......
  • 为什么TCP 建连接要3次,断连接却要4次呢?
    大家好,今天聊聊传输层通信协议TCP的经典问题:建连接与断连接。网络上的传输是没有连接的,包括TCP也是一样的。而TCP所谓的“连接”,其实只不过是在通讯的双方维护一个“连接状......
  • HP-ERS-T244 RS485/RS232四串口工业级串口服务器RS232/485转以太网TCP/IP物联网网关
     HP-ERS-T244是一款四串口服务器,采用Cortex-M7方案,主频高达400MHz,性能更强,传输速度更快,可靠性更高。搭载深度优化的TCP/IP协议栈。双重看门狗和多种保活机制助力设备稳......