一个有趣的实验---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状态没有变化(无感知), 大家可以思考一下。





原创粉丝点击