一个有趣的实验---tcp发送缓冲区满, 然后杀掉进程(处于FIN_WAIT1状态), 接收端是无感知的。
来源:互联网 发布:13.3寸mac玩cf分辨率 编辑:程序博客网 时间:2024/06/13 21:39
服务端程序:
#include <unistd.h>#include <sys/types.h>#include <sys/socket.h>#include <netdb.h>#include <stdio.h>#include <stdlib.h>#include <string.h>#include <ctype.h>#include <errno.h>#include <malloc.h>#include <netinet/in.h>#include <arpa/inet.h>#include <sys/ioctl.h>#include <stdarg.h>#include <fcntl.h>int main(){int sockSrv = socket(AF_INET, SOCK_STREAM, 0);struct sockaddr_in addrSrv;addrSrv.sin_family = AF_INET;addrSrv.sin_addr.s_addr = INADDR_ANY; addrSrv.sin_port = htons(8765);bind(sockSrv, (const struct sockaddr *)&addrSrv, sizeof(struct sockaddr_in));listen(sockSrv, 5);struct sockaddr_in addrClient;int len = sizeof(struct sockaddr_in);int sockConn = accept(sockSrv, (struct sockaddr *)&addrClient, (socklen_t*)&len);while(1) { getchar();char szRecvBuf[50001] = {0}; int iRet = recv(sockConn, szRecvBuf, sizeof(szRecvBuf) - 1, 0); printf("iRet is %d\n", iRet);} close(sockConn);close(sockSrv);return 0;}启动它。
客户端程序:
#include <unistd.h>#include <unistd.h>#include <sys/types.h>#include <sys/socket.h>#include <netdb.h>#include <stdio.h>#include <stdlib.h>#include <string.h>#include <ctype.h>#include <errno.h>#include <malloc.h>#include <netinet/in.h>#include <arpa/inet.h>#include <sys/ioctl.h>#include <stdarg.h>#include <fcntl.h>int main(){ int sockClient = socket(AF_INET, SOCK_STREAM, 0); struct sockaddr_in addrSrv; addrSrv.sin_addr.s_addr = inet_addr("10.100.70.140"); addrSrv.sin_family = AF_INET; addrSrv.sin_port = htons(8765); connect(sockClient, ( const struct sockaddr *)&addrSrv, sizeof(struct sockaddr_in));#define N 2000char szSendBuf[N] = {0};for(unsigned int i = 0; i < N; i++) //字符数组最后一个字符不要求是‘\0’{szSendBuf[i] = 'a';}int total = 0;while(1){int iRet = send(sockClient, szSendBuf, sizeof(szSendBuf) , 0); total += iRet;printf("iRet is %d, total send is %d\n", iRet, total);getchar();} close(sockClient); return 0;}启动它, 一直发送且服务端不recv数据, 此时客户端的内核缓冲区填满, send阻塞, ctrl c杀死进程, 此时客户端socket处于FIN_WAIT1状态。 客户端tcpdump抓包看不到FIN包和RST包, 而且服务端的socket也依然是ESTABLISHED的状态。
这个问题非常有意思, 其实客户端是发了FIN包的, 至于为什么tcpdump抓不到包, 且服务端socket状态没有变化(无感知), 大家可以思考一下。
阅读全文
0 0
- 一个有趣的实验---tcp发送缓冲区满, 然后杀掉进程(处于FIN_WAIT1状态), 接收端是无感知的。
- tcp socket的发送与接收缓冲区
- tcp socket的发送与接收缓冲区 .
- tcp socket的发送与接收缓冲区
- tcp socket的发送与接收缓冲区
- TCP socket的发送与接收缓冲区
- tcp socket的发送与接收缓冲区
- tcp socket的发送与接收缓冲区
- tcp的发送与接收缓冲区1
- linux tcp socket的发送与接收缓冲区
- 杀掉D状态的进程
- TCP接收/发送滑动窗口与内核接收/发送缓冲区之间的关系
- TCP接收/发送滑动窗口与内核接收/发送缓冲区之间的关系
- TCP接收/发送滑动窗口与内核接收/发送缓冲区之间的关系
- 透彻理解LINUX下TCP的发送缓冲区接收缓冲区与滑动窗口
- TCP的接收缓冲区满了,收到数据后会向发送方发送ACK吗?该怎么解决
- tcp四次挥手中FIN_WAIT1状态的最大时间是多长?
- 如何杀掉D状态的进程?[zt]
- 图片上传并预览
- JSP、Servlet乱码处理方法集合
- jQuery 实现的继承方式
- 选择移动框
- 00-LINUX基础服务
- 一个有趣的实验---tcp发送缓冲区满, 然后杀掉进程(处于FIN_WAIT1状态), 接收端是无感知的。
- 增删改查
- h5 安卓input输入框和改变div 字体颜色
- Vue axios处理http请求
- DB2创建联邦数据库
- 消息中间件简介
- Python网络爬虫(三)——Beutiful Soup库入门
- 远程使用jupyter
- 正则表达式