Skip to content

Commit 25d7e2e

Browse files
committed
Merge #17251: net: SocketHandler logs peer id for close and disconnect
04dbdd6 [net] SocketHandler: log peer id for close and disconnect (Sjors Provoost) Pull request description: When combined with `-logips` this makes it easier to diagnose disconnects. To test on macOS, find a connection you want to disrupt: ``` lsof -nP -iTCP:8333 -sTCP:ESTABLISHED ``` To shut it down gracefully you can use tcpkill or this Python script: https://github.com/google/tcp_killer The log should say: ``` 2019-10-25T13:26:55Z socket closed for peer=1 2019-10-25T13:26:55Z disconnecting peer=1 2019-10-25T13:26:55Z Cleared nodestate for peer=1 ``` To shut it down ungracefully I made a patch to the above script, adding a `-force` argument. _Careful, this may result in data corruption_. Then the log should say: ``` 2019-10-25T13:39:57Z socket select error Bad file descriptor (9) 2019-10-25T13:39:57Z socket recv error for peer=0: Bad file descriptor (9) 2019-10-25T13:39:57Z disconnecting peer=0 2019-10-25T13:39:57Z Socket close failed: 35. Error: Bad file descriptor (9) 2019-10-25T13:39:57Z Cleared nodestate for peer=0 ``` ACKs for top commit: MarcoFalke: unsigned ACK 04dbdd6 TheBlueMatt: unsigned ACK 04dbdd6 LGTM! theuni: unsigned ACK 04dbdd6. Tree-SHA512: 415313908484f97ffe11a48b4ed6afab3ab0be660c788adb9ad975f88b69aa1cfd5ccbe5859350cdf19ef8fde191fd530fb22cef34e70638defdc9f3d761c71d
2 parents 693e400 + 04dbdd6 commit 25d7e2e

File tree

1 file changed

+4
-3
lines changed

1 file changed

+4
-3
lines changed

src/net.cpp

Lines changed: 4 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -1361,7 +1361,7 @@ void CConnman::SocketHandler()
13611361
{
13621362
// socket closed gracefully
13631363
if (!pnode->fDisconnect) {
1364-
LogPrint(BCLog::NET, "socket closed\n");
1364+
LogPrint(BCLog::NET, "socket closed for peer=%d\n", pnode->GetId());
13651365
}
13661366
pnode->CloseSocketDisconnect();
13671367
}
@@ -1371,8 +1371,9 @@ void CConnman::SocketHandler()
13711371
int nErr = WSAGetLastError();
13721372
if (nErr != WSAEWOULDBLOCK && nErr != WSAEMSGSIZE && nErr != WSAEINTR && nErr != WSAEINPROGRESS)
13731373
{
1374-
if (!pnode->fDisconnect)
1375-
LogPrintf("socket recv error %s\n", NetworkErrorString(nErr));
1374+
if (!pnode->fDisconnect) {
1375+
LogPrint(BCLog::NET, "socket recv error for peer=%d: %s\n", pnode->GetId(), NetworkErrorString(nErr));
1376+
}
13761377
pnode->CloseSocketDisconnect();
13771378
}
13781379
}

0 commit comments

Comments
 (0)