TCP 연결이 끊어졌는지 확인하는 Golang의 방법:
keepalive 감지. Keepalive 설정의 경우 tcp가 피어 소켓을 더 이상 사용할 수 없음을 감지한 경우(감지 패킷을 보낼 수 없거나 감지 패킷이 ACK 응답을 받지 못함) 패킷), select는 소켓을 읽을 수 있음을 반환하고, recv 중에 -1이 반환되며, errno는 ETIMEDOUT으로 설정됩니다. 이때 TCP의 연결이 끊긴 상태입니다.
struct TCP_KEEPALIVE { unsigned long onoff; unsigned long keepalivetime; unsigned long keepaliveinterval; } ; #define SIO_KEEPALIVE_VALS _WSAIOW(IOC_VENDOR,4) /* KeepAlive实现 */ void set_keepalive (SOCKET s) { BOOL bKeepAlive = TRUE; int nRet = ::setsockopt(s, SOL_SOCKET, SO_KEEPALIVE, (char*)&bKeepAlive, sizeof(bKeepAlive)); if (nRet == SOCKET_ERROR) { return ; } /* 输入参数 */ struct TCP_KEEPALIVE inKeepAlive = {0}; unsigned long ulInLen = sizeof(struct TCP_KEEPALIVE); /* 输出参数 */ struct TCP_KEEPALIVE outKeepAlive = {0}; unsigned long ulOutLen = sizeof(struct TCP_KEEPALIVE); unsigned long ulBytesReturn = 0; int ret = 0; /* 设置keepalive 为5秒,并且发送次数为3次 */ inKeepAlive.onoff = 1; /* 2次keepalive探测间隔时间 */ inKeepAlive.keepaliveinterval = 5000; /* 开始首次keepalive探测前的tcp空闲时间 */ inKeepAlive.keepalivetime = 5000; ret = WSAIoctl((unsigned int)s, SIO_KEEPALIVE_VALS, (LPVOID)&inKeepAlive, ulInLen, (LPVOID)&outKeepAlive, ulOutLen, &ulBytesReturn, NULL, NULL); if (ret == SOCKET_ERROR) { printf ("error: %d\n", WSAGetLastError()); } }
더 많은 golang 지식을 알고 싶다면 golang tutorial 칼럼을 주목해주세요.
위 내용은 golang에서 TCP 연결이 끊어졌는지 확인하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!