基于TCP传输的网络编程异常处理
来源:互联网 发布:nginx 允许访问目录 编辑:程序博客网 时间:2024/05/29 16:52
基于TCP传输的网络编程异常处理
一:进程一端退出(exit,CTRL+C,挂掉)(跟主动CLOSE、主动关机一样)
内核会关闭所有句柄触发FIN分节发送(但如果设置了SO_LINGER l_onoff为1,则发送RST分节对方)
FIN分节处理: 另一端recv 返回0 表示对端结束
RST分节处理: 另一端recv 返回-1 表示对端错误,错误码为connection reset by peer
如果另一端send 则会导致进程接收SIGPIPE信号,该信号默认终止进程,
需要signal(SIGPIPE,SIG_IGN);
二:一端主机崩溃(非主动关机)、中间路由不通
另一个发送的数据内核会重传,发送缓存区数据一直增加
设置的发送超时只要发送缓存区能装的下,send就不会报错的(记住send只是拷贝数据到内核)
如何检测另一个端死了,必须采用以下方法
1.开启KEEP_ALIVE 心跳机制
2.应用层心跳机制
三:服务器主机崩溃后重启
之前TCP连接信息已丢失,对后续接收到的客户端以RST响应;
当然也可能在重启前就已经通过心跳机制检测到了异常
附非正常结束和正常结束及TCP状态切换图
0 0
- 基于TCP传输的网络编程异常处理
- java 网络编程 基于TCP ,UDP的网络传输
- 网络编程--tcp传输
- 网络编程:基于TCP的socket网络传输视频(C++, python)
- 【网络编程】TCP异常断开处理方法
- 基于TCP的网络编程
- 基于TCP的网络编程
- 网络编程应用:基于TCP协议【实现对象传输】--练习
- c/c++网络编程 对象的传输 以及 TCP粘包处理 解析
- 网络编程----基于TCP的socket编程
- Java-网络编程(TCP传输)
- 基于TCP、UDP网络传输的实例分析
- 基于TCP、UDP网络传输的实例分析
- Java Socket编程 - 基于TCP方式的二进制文件传输
- 网络TCp数据的传输设计(黏包处理)
- 基于TCP/IP的网络编程步骤
- 基于TCP 的网络编程步骤
- 基于Linux的TCP网络编程
- java 集合与数组的互转
- 1
- Opencv3神经网络的使用
- java excel api(jxl.jar)库基础操作学习
- JSTL、EL、ONGL、Struts标签的区别与使用
- 基于TCP传输的网络编程异常处理
- 如何自定义控件
- Game Programming Using QT第三章
- ECC加密算法入门介绍
- Hessiana入门Demo
- 求一个大于500行代码的汇编游戏
- Java中常用的web服务器
- ionic2文档整理
- linux常见操作指令