大量TIME_WAIT解决方案
问题
TIME_WAIT状态是主动断开连接的一方产生的,客户端处于TIME_WAIT状态的话问题不大,如果服务器产生大量TIME_WAIT状态的连接,就会大大降低服务器的响应速度等性能问题,根本原因是一些端口号以及socket地址被占用而得不到释放。
方法一
C/C++中提供了一个接口,如果服务器重启时需要对端口号以及socket地址进行复用,从而避免了TIME_WAIT状态
#include <sys/types.h>
#include <sys/socket.h>
int setsockopt(int sockfd, int level, int optname,
const void *optval, socklen_t optlen);
具体应用举例:
设置调用close(socket)后,仍可继续重用该socket。调用close(socket)一般不会立即关闭socket,而经历TIME_WAIT的过程。
BOOL bReuseaddr = TRUE;
setsockopt( s, SOL_SOCKET, SO_REUSEADDR, ( const char* )&bReuseaddr, sizeof( BOOL ) );
如果要已经处于连接状态的soket在调用closesocket()后强制关闭,不经历TIME_WAIT的过程:
BOOL bDontLinger = FALSE;
setsockopt( s, SOL_SOCKET, SO_DONTLINGER, ( const char* )&bDontLinger, sizeof( BOOL ) );
方法二
通过修改Linux内核的方式解决该问题
添加配置信息
让参数配置生效
/sbin/sysctl -p
这样就可以解决了,其实两个方法原理相似,只不过实现方法不一样
原文搬运至此
https://blog.csdn.net/IT_xiaoye/article/details/80926910