41-连接异常(服务器崩溃后重启)
来源:互联网 发布:vb高级教学视频教程 编辑:程序博客网 时间:2024/06/03 20:21
这一种情况比上一篇崩溃后不重启的情况要简单的多,区别就在于让服务器(机器)崩溃,然后重新启动机器。
请务必复习《半打开的 TCP 连接》。
1. 程序路径
代码托管在 gitos 上,请使用下面的命令获取:
git clone https://git.oschina.net/ivan_allen/unp.git
如果你已经 clone 过这个代码了,请使用 git pull 更新一下。本节程序所使用的程序路径是unp/program/echo/processzombie
。
2. 实验步骤
- 在 flower 机器上启动服务器
flower $ ./echo -s -h flower
- 在 sun 机器上启动客户端
sun $ ./echo -h flower
发送一行数据'helloworld'
,得到服务器回射,目前一切正常。
图1 客户端与服务器正常通信
- 断开 flower 主机的网络,然后将 echo 服务器进程关闭。
- 随时使用
netstat -ant
命令查看 echo 服务器目前的状态,如果是 FIN_WAIT1 状态,暂时还不能恢复 flower 的网络,直到 FIN_WAIT1 状态消失为止,大约要等个几分钟吧。 确认 flower 主机上的 FIN_WAIT1 状态消失后,恢复 flower 主机的网络,要不要再次启动 echo 服务器都无所谓,因为最终结果都一样。
客户端此时并不知道 flower 主机已经重启,又向 flower 发送了数据,图 2.
图2 sun 客户端向 flower 发送了
'nihao'
,flower 回送了 RST 段 3. 结果分析
虽然 flower 崩溃后重启(我们使用断网来模拟的),但是客户端对此毫不知情,客户端此时却仍然持有着一个《半打开的连接》,若继续向对端发送数据,flower 主机可以收到此报文,但是并不认识这个连接(因为 flower 已经重启,之前的连接早已不存在),因此回复了一个 RST 段。
4. 总结
- 掌握服务器崩溃后重启,客户端的行为
0 0
- 41-连接异常(服务器崩溃后重启)
- 40-连接异常(服务器崩溃)
- 捕获程序崩溃异常上传到服务器
- JProfiler 连接服务器异常,解决方案
- ASmack连接Openfire服务器异常
- 服务器主动断开连接异常
- MSSQL_连接异常_网络连接异常(无法连接到服务器)_无法连接到WMI提供程序
- 38-连接断开异常(服务器进程终止)
- 捕获崩溃异常并重启程序,上传崩溃日志到服务器
- 服务器崩溃
- 服务器崩溃
- UNIX编程专题-服务器进程终止/服务器主机崩溃/服务器主机崩溃后重启/服务器主机关机
- xcode 异常崩溃(代码级)
- iOS崩溃 捕获异常处理(二)
- logcat抓取(崩溃、超时、异常、错误)
- 连接服务器异常处理详细名称
- websocket客户端与TCP服务器连接异常
- [Exc异常记录]未安装memcached导致服务器连接异常
- mac跑opencv的kcf追踪
- 简单介绍 DOCTYPE
- el jstl使用
- 【python学习笔记】4:精度控制/文件读/split()方法
- LeetCode-118、119. Pascal's Triangle (JAVA)杨辉三角
- 41-连接异常(服务器崩溃后重启)
- android 混淆文件proguard.cfg详解
- Qt-QML-Button-ButtonStyle-实现鼠标滑过点击效果
- juery访问dom元素与传统js访问dom元素的不同
- 覆盖
- Recyclerview 实现listView的代码
- msysgit初次安装
- org.apache.ibatis.builder.IncompleteElementException: Could not find parameter map com.vo.app
- PS_BaseUse_两张图片置入融合