TCP 协议小研究

本文详细解析了TCP协议中的重传机制及TIME_WAIT状态,通过启动服务程序、监听客户端连接、数据发送与接收等步骤,展示了TCP如何在数据传输中实现可靠性和稳定性。同时解释了TIME_WAIT状态的意义,包括它在连接关闭过程中的作用以及如何确保客户端正确地确认服务器的关闭信号。

目录:


TCP重传机制

client: 192.168.128.1server:192.168.128.129

server 为一个简单监听程序,收到数据后打印,然后再读取流(阻塞)

1、启动服务程序: java -jar tcp-0.0.1-SNAPSHOT.jar -server -serverport 2222

2、监听服务器 2222端口:

tcpdump -n -S tcp port 2222


3、启动client 程序:

java -jar tcp-0.0.1-SNAPSHOT.jar -client -serveraddress 192.168.128.129 -serverport 2222

此时服务器会显示三次握手:


4、查看client 连接端口:

netstat --an查出端口号:53229

5、建立client 的端口监听:windump  -n -S tcp port 53229,然后 client向server 发送数据:查看监听数据如下:

server : 

表示server 已经收到了client 发来的数据

下面看看client 中的数据监听情况:

可以看到client 监听到的数据是一样

6、断开服务器网线,然后client 再向服务器发送数

client 监听到的数据:



从上图可以看出,client 在发送后并没有得到确认信息后,同时会在不同时间间隔内重新发送数据,这就是TCP协议中的重传机制!

TIME_WAIT 意义:

tcp 在关闭连接时,如下图:

 在 client 收到 server 的 ACK 后,client 是已经完成了自己的关闭,进入 FIN_WAIT_2 阶段,而server 在发送 FIN时,client 收到server 的FIN后进入 TIME_WAIT(此时收到server FIN,client就知道server也执行关闭操作,而此时整个连接就已经关闭了),但 server并不知道client 已经收到了 FIN,因此,client还要给server 返回一个ack,

server 在收到最后一个ack 后,才能确认client 已经收到了FIN,但问题又来了,client 怎么知道自己把最后的 ack 发了过去,怎么知道server 确实收到了自己的ack,因此server 在收到最后一个ack后不会再向client 发送任何信息了,因此,此时就提出了让client 等候一段时间,这段时间就是为了最后一个ack而准备的,如果ack 真的没有发到,则

server 会重发 FIN,client 在 TIME_WAIT 阶段会处理FIN,然后再次发送 最后一个ACK,

因此,TIME_WAIT 就是为了确认 server 重发的 FIN ,注意:TIME_wait只会存在于进行主动关闭的那一端,如果你在一个client 主动关闭,而且你下次以同一个端口启动cilent时,此时会通知:can't bind local address: Address already in use,而我们在主动关闭client时却不报此异常是因此我们的client 每次启动都是由系统分配的不同端口



TCP 呼入队列

TCP 有一个等待连接固定长度人队列,当服务端CPU繁忙时无法处理连接时,系统TCP模块会将其进行确认,也就是进行三次握手,而后将请求放入呼入队列,一般队列长度默认为5,如果队列慢,对于client再次发过来的 请求,server 端的TCP模块就不再进行处理,也不会进行任何响应,client  经过几次重发后就进入了 超时而断开。

使用sock 以下试验:

sock -s -q 1 -O 10000000 2222  q1 指定队列长度 -O TCP在指定时间后再去处理请求


半打开



代码转载自:https://pan.quark.cn/s/8ce4326d996e 对于在 CentOS 7 系统中修改网卡配置文件后无法使设置生效的情况,经过实践验证,可以通过使用 nmcli 命令来进行调整。完成修改之后,需要重新启动虚拟机以使更改生效,这样操作流程即告完成。如果设置仍然无法生效,则表明虚拟机在启动过程中所获取的 IP 地址配置并非针对 eth0,此时可以对其它网卡的配置文件进行修改或将其移除。在 CentOS 7 系统中,网络配置的管理机制与早期版本存在差异,主要体现为采用了 Network Manager 服务来负责网络接口的管理。在某些情形下,尽管修改了 `/etc/sysconfig/network-scripts` 目录下的 `ifcfg-eth0` 文件,但网络配置却未能即时生效。此类问题的发生通常源于 CentOS 7 采用了不同于以往的配置读取方法。接下来将具体阐述如何借助 nmcli 命令来处理这一挑战。 以 root 用户身份登录系统并打开终端界面。nmcli 是 Network Manager 提供的命令行界面工具,它支持在命令行环境下执行网络连接的建立、编辑、查询及管理任务。针对修改 eth0 网卡配置的需求,可以遵循以下步骤进行操作: 1. 导航至 `/etc/sysconfig/network-scripts` 目录: ``` cd /etc/sysconfig/network-scripts ``` 2. 检查该目录内是否存在 `ifcfg-eth0.bak` 文件,该备份文件可能是先前调整配置时遗留下来的,若存在可能造成冲突。若发现该文件,可以选择将其删除: ``` [root@localhost netw...
代码转载自:https://pan.quark.cn/s/46fd08fb879c 网管教程 从入门到精通软件篇 ★一。★详尽的xp修复控制台指令及其应用!!! 放入xp(2000)的光盘,安装时选择R,执行修复! Windows XP(涵盖 Windows 2000)的控制台指令是在系统遭遇某些意外状况时的一种极具效用的诊断、检测以及恢复系统功能的工具。笔者确实一直期望能够将这方面的指令进行归纳,此次由老范辛苦整理了这份极具价值的秘籍。 Bootcfg bootcfg 命令用于启动配置与故障恢复(对大多数计算机而言,即 boot.ini 文件)。 带有特定参数的 bootcfg 命令仅在运用故障恢复控制台时方可使用。能够在命令行界面下运用带有不同参数的 bootcfg 命令。 用法: bootcfg /default 设定默认引导选项。 bootcfg /add 向引导清单中增添 Windows 安装。 bootcfg /rebuild 重复整个 Windows 安装流程并让用户选择需添加的项目。 注意:运用 bootcfg /rebuild 之前,应先借助 bootcfg /copy 命令备份 boot.ini 文件。 bootcfg /scan 探查用于 Windows 安装的全部磁盘并展示结果。 注意:这些结果被静态存储,并用于当前会话。若在当前会话期间磁盘配置发生变动,为获取更新的探查结果,必须先重启计算机,然后再次探查磁盘。 bootcfg /list 列示引导清单中已有的项目。 bootcfg /disableredirect 在启动引导程序中禁用重定向。 bootcfg /redirect [ PortBaudRrate] |[ useBio...
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值