mirror of
https://github.com/bitcoin/bitcoin.git
synced 2025-01-09 19:37:27 -03:00
Merge bitcoin/bitcoin#28521: net, net_processing: additional and consistent disconnect logging
Some checks are pending
CI / test each commit (push) Waiting to run
CI / macOS 14 native, arm64, no depends, sqlite only, gui (push) Waiting to run
CI / macOS 14 native, arm64, fuzz (push) Waiting to run
CI / Win64 native, VS 2022 (push) Waiting to run
CI / Win64 native fuzz, VS 2022 (push) Waiting to run
CI / ASan + LSan + UBSan + integer, no depends, USDT (push) Waiting to run
Some checks are pending
CI / test each commit (push) Waiting to run
CI / macOS 14 native, arm64, no depends, sqlite only, gui (push) Waiting to run
CI / macOS 14 native, arm64, fuzz (push) Waiting to run
CI / Win64 native, VS 2022 (push) Waiting to run
CI / Win64 native fuzz, VS 2022 (push) Waiting to run
CI / ASan + LSan + UBSan + integer, no depends, USDT (push) Waiting to run
06443b8f28
net: clarify if we ever sent or received from peer (Sjors Provoost)1d01ad4d73
net: add LogIP() helper, use in net_processing (Sjors Provoost)937ef9eb40
net_processing: use CNode::DisconnectMsg helper (Sjors Provoost)ad224429f8
net: additional disconnection logging (Sjors Provoost) Pull request description: While debugging unexpected disconnections, possibly related to #28331, I found some additional [net] logging to be useful. All cases where we disconnect now come with a log message that has the word `disconnecting`: * all calls to `CloseSocketDisconnect()` log `disconnecting peer=…` * wherever we set `pnode->fDisconnect = true;` * for all `InactivityCheck` cases (which in turn sets `fDisconnect`) * replaces "dropping" with "disconnecting" in `Network not active, dropping peer=…` A few exceptions are listed here: https://github.com/bitcoin/bitcoin/pull/28521#discussion_r1890824361 I changed `CloseSocketDisconnect()` to no longer log `disconnecting`, and instead have all the call sites do so. This PR introduces two helper functions on `CNode`: `DisconnectMsg` and `LogIP`. The second and third commit use these helpers in `net_processing.cpp` so these disconnect messages are more consistent now (e.g. some didn't log the IP). No new messages are added there though. The `LogIP()` helper is rarely used outside of a disconnect event, but it's available for future use. Any `LogPrint` this PR touches is replaced with `LogDebug` (superseded by #30750), and every `LogPrintf ` with `LogInfo`. ACKs for top commit: davidgumberg: reACK06443b8f28
vasild: ACK06443b8f28
danielabrozzoni: ACK06443b8f28
hodlinator: ACK06443b8f28
Tree-SHA512: 525f4c11568616e1d48455a3fcab9e923da7432377fe9230468c15403d2e9b7ce712112df8fbd547cfec01dce0d1f26107cfc1b90f78cfc1fe13e08d57b08464
This commit is contained in:
commit
f95fb79372
9 changed files with 123 additions and 75 deletions
55
src/net.cpp
55
src/net.cpp
|
@ -558,7 +558,6 @@ void CNode::CloseSocketDisconnect()
|
||||||
fDisconnect = true;
|
fDisconnect = true;
|
||||||
LOCK(m_sock_mutex);
|
LOCK(m_sock_mutex);
|
||||||
if (m_sock) {
|
if (m_sock) {
|
||||||
LogDebug(BCLog::NET, "disconnecting peer=%d\n", id);
|
|
||||||
m_sock.reset();
|
m_sock.reset();
|
||||||
}
|
}
|
||||||
m_i2p_sam_session.reset();
|
m_i2p_sam_session.reset();
|
||||||
|
@ -696,6 +695,18 @@ bool CNode::ReceiveMsgBytes(Span<const uint8_t> msg_bytes, bool& complete)
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
std::string CNode::LogIP(bool log_ip) const
|
||||||
|
{
|
||||||
|
return log_ip ? strprintf(" peeraddr=%s", addr.ToStringAddrPort()) : "";
|
||||||
|
}
|
||||||
|
|
||||||
|
std::string CNode::DisconnectMsg(bool log_ip) const
|
||||||
|
{
|
||||||
|
return strprintf("disconnecting peer=%d%s",
|
||||||
|
GetId(),
|
||||||
|
LogIP(log_ip));
|
||||||
|
}
|
||||||
|
|
||||||
V1Transport::V1Transport(const NodeId node_id) noexcept
|
V1Transport::V1Transport(const NodeId node_id) noexcept
|
||||||
: m_magic_bytes{Params().MessageStart()}, m_node_id{node_id}
|
: m_magic_bytes{Params().MessageStart()}, m_node_id{node_id}
|
||||||
{
|
{
|
||||||
|
@ -1635,7 +1646,7 @@ std::pair<size_t, bool> CConnman::SocketSendData(CNode& node) const
|
||||||
// error
|
// error
|
||||||
int nErr = WSAGetLastError();
|
int nErr = WSAGetLastError();
|
||||||
if (nErr != WSAEWOULDBLOCK && nErr != WSAEMSGSIZE && nErr != WSAEINTR && nErr != WSAEINPROGRESS) {
|
if (nErr != WSAEWOULDBLOCK && nErr != WSAEMSGSIZE && nErr != WSAEINTR && nErr != WSAEINPROGRESS) {
|
||||||
LogDebug(BCLog::NET, "socket send error for peer=%d: %s\n", node.GetId(), NetworkErrorString(nErr));
|
LogDebug(BCLog::NET, "socket send error, %s: %s\n", node.DisconnectMsg(fLogIPs), NetworkErrorString(nErr));
|
||||||
node.CloseSocketDisconnect();
|
node.CloseSocketDisconnect();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1879,7 +1890,7 @@ void CConnman::DisconnectNodes()
|
||||||
// Disconnect any connected nodes
|
// Disconnect any connected nodes
|
||||||
for (CNode* pnode : m_nodes) {
|
for (CNode* pnode : m_nodes) {
|
||||||
if (!pnode->fDisconnect) {
|
if (!pnode->fDisconnect) {
|
||||||
LogDebug(BCLog::NET, "Network not active, dropping peer=%d\n", pnode->GetId());
|
LogDebug(BCLog::NET, "Network not active, %s\n", pnode->DisconnectMsg(fLogIPs));
|
||||||
pnode->fDisconnect = true;
|
pnode->fDisconnect = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1971,26 +1982,43 @@ bool CConnman::InactivityCheck(const CNode& node) const
|
||||||
|
|
||||||
if (!ShouldRunInactivityChecks(node, now)) return false;
|
if (!ShouldRunInactivityChecks(node, now)) return false;
|
||||||
|
|
||||||
if (last_recv.count() == 0 || last_send.count() == 0) {
|
bool has_received{last_recv.count() != 0};
|
||||||
LogDebug(BCLog::NET, "socket no message in first %i seconds, %d %d peer=%d\n", count_seconds(m_peer_connect_timeout), last_recv.count() != 0, last_send.count() != 0, node.GetId());
|
bool has_sent{last_send.count() != 0};
|
||||||
|
|
||||||
|
if (!has_received || !has_sent) {
|
||||||
|
std::string has_never;
|
||||||
|
if (!has_received) has_never += ", never received from peer";
|
||||||
|
if (!has_sent) has_never += ", never sent to peer";
|
||||||
|
LogDebug(BCLog::NET,
|
||||||
|
"socket no message in first %i seconds%s, %s\n",
|
||||||
|
count_seconds(m_peer_connect_timeout),
|
||||||
|
has_never,
|
||||||
|
node.DisconnectMsg(fLogIPs)
|
||||||
|
);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (now > last_send + TIMEOUT_INTERVAL) {
|
if (now > last_send + TIMEOUT_INTERVAL) {
|
||||||
LogDebug(BCLog::NET, "socket sending timeout: %is peer=%d\n", count_seconds(now - last_send), node.GetId());
|
LogDebug(BCLog::NET,
|
||||||
|
"socket sending timeout: %is, %s\n", count_seconds(now - last_send),
|
||||||
|
node.DisconnectMsg(fLogIPs)
|
||||||
|
);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (now > last_recv + TIMEOUT_INTERVAL) {
|
if (now > last_recv + TIMEOUT_INTERVAL) {
|
||||||
LogDebug(BCLog::NET, "socket receive timeout: %is peer=%d\n", count_seconds(now - last_recv), node.GetId());
|
LogDebug(BCLog::NET,
|
||||||
|
"socket receive timeout: %is, %s\n", count_seconds(now - last_recv),
|
||||||
|
node.DisconnectMsg(fLogIPs)
|
||||||
|
);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!node.fSuccessfullyConnected) {
|
if (!node.fSuccessfullyConnected) {
|
||||||
if (node.m_transport->GetInfo().transport_type == TransportProtocolType::DETECTING) {
|
if (node.m_transport->GetInfo().transport_type == TransportProtocolType::DETECTING) {
|
||||||
LogDebug(BCLog::NET, "V2 handshake timeout peer=%d\n", node.GetId());
|
LogDebug(BCLog::NET, "V2 handshake timeout, %s\n", node.DisconnectMsg(fLogIPs));
|
||||||
} else {
|
} else {
|
||||||
LogDebug(BCLog::NET, "version handshake timeout peer=%d\n", node.GetId());
|
LogDebug(BCLog::NET, "version handshake timeout, %s\n", node.DisconnectMsg(fLogIPs));
|
||||||
}
|
}
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -2118,6 +2146,10 @@ void CConnman::SocketHandlerConnected(const std::vector<CNode*>& nodes,
|
||||||
{
|
{
|
||||||
bool notify = false;
|
bool notify = false;
|
||||||
if (!pnode->ReceiveMsgBytes({pchBuf, (size_t)nBytes}, notify)) {
|
if (!pnode->ReceiveMsgBytes({pchBuf, (size_t)nBytes}, notify)) {
|
||||||
|
LogDebug(BCLog::NET,
|
||||||
|
"receiving message bytes failed, %s\n",
|
||||||
|
pnode->DisconnectMsg(fLogIPs)
|
||||||
|
);
|
||||||
pnode->CloseSocketDisconnect();
|
pnode->CloseSocketDisconnect();
|
||||||
}
|
}
|
||||||
RecordBytesRecv(nBytes);
|
RecordBytesRecv(nBytes);
|
||||||
|
@ -2130,7 +2162,7 @@ void CConnman::SocketHandlerConnected(const std::vector<CNode*>& nodes,
|
||||||
{
|
{
|
||||||
// socket closed gracefully
|
// socket closed gracefully
|
||||||
if (!pnode->fDisconnect) {
|
if (!pnode->fDisconnect) {
|
||||||
LogDebug(BCLog::NET, "socket closed for peer=%d\n", pnode->GetId());
|
LogDebug(BCLog::NET, "socket closed, %s\n", pnode->DisconnectMsg(fLogIPs));
|
||||||
}
|
}
|
||||||
pnode->CloseSocketDisconnect();
|
pnode->CloseSocketDisconnect();
|
||||||
}
|
}
|
||||||
|
@ -2141,7 +2173,7 @@ void CConnman::SocketHandlerConnected(const std::vector<CNode*>& nodes,
|
||||||
if (nErr != WSAEWOULDBLOCK && nErr != WSAEMSGSIZE && nErr != WSAEINTR && nErr != WSAEINPROGRESS)
|
if (nErr != WSAEWOULDBLOCK && nErr != WSAEMSGSIZE && nErr != WSAEINTR && nErr != WSAEINPROGRESS)
|
||||||
{
|
{
|
||||||
if (!pnode->fDisconnect) {
|
if (!pnode->fDisconnect) {
|
||||||
LogDebug(BCLog::NET, "socket recv error for peer=%d: %s\n", pnode->GetId(), NetworkErrorString(nErr));
|
LogDebug(BCLog::NET, "socket recv error, %s: %s\n", pnode->DisconnectMsg(fLogIPs), NetworkErrorString(nErr));
|
||||||
}
|
}
|
||||||
pnode->CloseSocketDisconnect();
|
pnode->CloseSocketDisconnect();
|
||||||
}
|
}
|
||||||
|
@ -3411,6 +3443,7 @@ void CConnman::StopNodes()
|
||||||
std::vector<CNode*> nodes;
|
std::vector<CNode*> nodes;
|
||||||
WITH_LOCK(m_nodes_mutex, nodes.swap(m_nodes));
|
WITH_LOCK(m_nodes_mutex, nodes.swap(m_nodes));
|
||||||
for (CNode* pnode : nodes) {
|
for (CNode* pnode : nodes) {
|
||||||
|
LogDebug(BCLog::NET, "%s\n", pnode->DisconnectMsg(fLogIPs));
|
||||||
pnode->CloseSocketDisconnect();
|
pnode->CloseSocketDisconnect();
|
||||||
DeleteNode(pnode);
|
DeleteNode(pnode);
|
||||||
}
|
}
|
||||||
|
|
16
src/net.h
16
src/net.h
|
@ -947,6 +947,22 @@ public:
|
||||||
|
|
||||||
std::string ConnectionTypeAsString() const { return ::ConnectionTypeAsString(m_conn_type); }
|
std::string ConnectionTypeAsString() const { return ::ConnectionTypeAsString(m_conn_type); }
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Helper function to optionally log the IP address.
|
||||||
|
*
|
||||||
|
* @param[in] log_ip whether to include the IP address
|
||||||
|
* @return " peeraddr=..." or ""
|
||||||
|
*/
|
||||||
|
std::string LogIP(bool log_ip) const;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Helper function to log disconnects.
|
||||||
|
*
|
||||||
|
* @param[in] log_ip whether to include the IP address
|
||||||
|
* @return "disconnecting peer=..." and optionally "peeraddr=..."
|
||||||
|
*/
|
||||||
|
std::string DisconnectMsg(bool log_ip) const;
|
||||||
|
|
||||||
/** A ping-pong round trip has completed successfully. Update latest and minimum ping times. */
|
/** A ping-pong round trip has completed successfully. Update latest and minimum ping times. */
|
||||||
void PongReceived(std::chrono::microseconds ping_time) {
|
void PongReceived(std::chrono::microseconds ping_time) {
|
||||||
m_last_ping_time = ping_time;
|
m_last_ping_time = ping_time;
|
||||||
|
|
|
@ -2238,7 +2238,7 @@ void PeerManagerImpl::ProcessGetBlockData(CNode& pfrom, Peer& peer, const CInv&
|
||||||
(((m_chainman.m_best_header != nullptr) && (m_chainman.m_best_header->GetBlockTime() - pindex->GetBlockTime() > HISTORICAL_BLOCK_AGE)) || inv.IsMsgFilteredBlk()) &&
|
(((m_chainman.m_best_header != nullptr) && (m_chainman.m_best_header->GetBlockTime() - pindex->GetBlockTime() > HISTORICAL_BLOCK_AGE)) || inv.IsMsgFilteredBlk()) &&
|
||||||
!pfrom.HasPermission(NetPermissionFlags::Download) // nodes with the download permission may exceed target
|
!pfrom.HasPermission(NetPermissionFlags::Download) // nodes with the download permission may exceed target
|
||||||
) {
|
) {
|
||||||
LogDebug(BCLog::NET, "historical block serving limit reached, disconnect peer=%d\n", pfrom.GetId());
|
LogDebug(BCLog::NET, "historical block serving limit reached, %s\n", pfrom.DisconnectMsg(fLogIPs));
|
||||||
pfrom.fDisconnect = true;
|
pfrom.fDisconnect = true;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -2247,7 +2247,7 @@ void PeerManagerImpl::ProcessGetBlockData(CNode& pfrom, Peer& peer, const CInv&
|
||||||
if (!pfrom.HasPermission(NetPermissionFlags::NoBan) && (
|
if (!pfrom.HasPermission(NetPermissionFlags::NoBan) && (
|
||||||
(((peer.m_our_services & NODE_NETWORK_LIMITED) == NODE_NETWORK_LIMITED) && ((peer.m_our_services & NODE_NETWORK) != NODE_NETWORK) && (tip->nHeight - pindex->nHeight > (int)NODE_NETWORK_LIMITED_MIN_BLOCKS + 2 /* add two blocks buffer extension for possible races */) )
|
(((peer.m_our_services & NODE_NETWORK_LIMITED) == NODE_NETWORK_LIMITED) && ((peer.m_our_services & NODE_NETWORK) != NODE_NETWORK) && (tip->nHeight - pindex->nHeight > (int)NODE_NETWORK_LIMITED_MIN_BLOCKS + 2 /* add two blocks buffer extension for possible races */) )
|
||||||
)) {
|
)) {
|
||||||
LogDebug(BCLog::NET, "Ignore block request below NODE_NETWORK_LIMITED threshold, disconnect peer=%d\n", pfrom.GetId());
|
LogDebug(BCLog::NET, "Ignore block request below NODE_NETWORK_LIMITED threshold, %s\n", pfrom.DisconnectMsg(fLogIPs));
|
||||||
//disconnect node and prevent it from stalling (would otherwise wait for the missing block)
|
//disconnect node and prevent it from stalling (would otherwise wait for the missing block)
|
||||||
pfrom.fDisconnect = true;
|
pfrom.fDisconnect = true;
|
||||||
return;
|
return;
|
||||||
|
@ -2270,9 +2270,9 @@ void PeerManagerImpl::ProcessGetBlockData(CNode& pfrom, Peer& peer, const CInv&
|
||||||
std::vector<uint8_t> block_data;
|
std::vector<uint8_t> block_data;
|
||||||
if (!m_chainman.m_blockman.ReadRawBlockFromDisk(block_data, block_pos)) {
|
if (!m_chainman.m_blockman.ReadRawBlockFromDisk(block_data, block_pos)) {
|
||||||
if (WITH_LOCK(m_chainman.GetMutex(), return m_chainman.m_blockman.IsBlockPruned(*pindex))) {
|
if (WITH_LOCK(m_chainman.GetMutex(), return m_chainman.m_blockman.IsBlockPruned(*pindex))) {
|
||||||
LogDebug(BCLog::NET, "Block was pruned before it could be read, disconnect peer=%s\n", pfrom.GetId());
|
LogDebug(BCLog::NET, "Block was pruned before it could be read, %s\n", pfrom.DisconnectMsg(fLogIPs));
|
||||||
} else {
|
} else {
|
||||||
LogError("Cannot load block from disk, disconnect peer=%d\n", pfrom.GetId());
|
LogError("Cannot load block from disk, %s\n", pfrom.DisconnectMsg(fLogIPs));
|
||||||
}
|
}
|
||||||
pfrom.fDisconnect = true;
|
pfrom.fDisconnect = true;
|
||||||
return;
|
return;
|
||||||
|
@ -2284,9 +2284,9 @@ void PeerManagerImpl::ProcessGetBlockData(CNode& pfrom, Peer& peer, const CInv&
|
||||||
std::shared_ptr<CBlock> pblockRead = std::make_shared<CBlock>();
|
std::shared_ptr<CBlock> pblockRead = std::make_shared<CBlock>();
|
||||||
if (!m_chainman.m_blockman.ReadBlockFromDisk(*pblockRead, block_pos)) {
|
if (!m_chainman.m_blockman.ReadBlockFromDisk(*pblockRead, block_pos)) {
|
||||||
if (WITH_LOCK(m_chainman.GetMutex(), return m_chainman.m_blockman.IsBlockPruned(*pindex))) {
|
if (WITH_LOCK(m_chainman.GetMutex(), return m_chainman.m_blockman.IsBlockPruned(*pindex))) {
|
||||||
LogDebug(BCLog::NET, "Block was pruned before it could be read, disconnect peer=%s\n", pfrom.GetId());
|
LogDebug(BCLog::NET, "Block was pruned before it could be read, %s\n", pfrom.DisconnectMsg(fLogIPs));
|
||||||
} else {
|
} else {
|
||||||
LogError("Cannot load block from disk, disconnect peer=%d\n", pfrom.GetId());
|
LogError("Cannot load block from disk, %s\n", pfrom.DisconnectMsg(fLogIPs));
|
||||||
}
|
}
|
||||||
pfrom.fDisconnect = true;
|
pfrom.fDisconnect = true;
|
||||||
return;
|
return;
|
||||||
|
@ -2788,7 +2788,7 @@ void PeerManagerImpl::UpdatePeerStateForReceivedHeaders(CNode& pfrom, Peer& peer
|
||||||
// the minimum chain work, even if a peer has a chain past our tip,
|
// the minimum chain work, even if a peer has a chain past our tip,
|
||||||
// as an anti-DoS measure.
|
// as an anti-DoS measure.
|
||||||
if (pfrom.IsOutboundOrBlockRelayConn()) {
|
if (pfrom.IsOutboundOrBlockRelayConn()) {
|
||||||
LogPrintf("Disconnecting outbound peer %d -- headers chain has insufficient work\n", pfrom.GetId());
|
LogInfo("outbound peer headers chain has insufficient work, %s\n", pfrom.DisconnectMsg(fLogIPs));
|
||||||
pfrom.fDisconnect = true;
|
pfrom.fDisconnect = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -3111,8 +3111,8 @@ bool PeerManagerImpl::PrepareBlockFilterRequest(CNode& node, Peer& peer,
|
||||||
(filter_type == BlockFilterType::BASIC &&
|
(filter_type == BlockFilterType::BASIC &&
|
||||||
(peer.m_our_services & NODE_COMPACT_FILTERS));
|
(peer.m_our_services & NODE_COMPACT_FILTERS));
|
||||||
if (!supported_filter_type) {
|
if (!supported_filter_type) {
|
||||||
LogDebug(BCLog::NET, "peer %d requested unsupported block filter type: %d\n",
|
LogDebug(BCLog::NET, "peer requested unsupported block filter type: %d, %s\n",
|
||||||
node.GetId(), static_cast<uint8_t>(filter_type));
|
static_cast<uint8_t>(filter_type), node.DisconnectMsg(fLogIPs));
|
||||||
node.fDisconnect = true;
|
node.fDisconnect = true;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -3123,8 +3123,8 @@ bool PeerManagerImpl::PrepareBlockFilterRequest(CNode& node, Peer& peer,
|
||||||
|
|
||||||
// Check that the stop block exists and the peer would be allowed to fetch it.
|
// Check that the stop block exists and the peer would be allowed to fetch it.
|
||||||
if (!stop_index || !BlockRequestAllowed(stop_index)) {
|
if (!stop_index || !BlockRequestAllowed(stop_index)) {
|
||||||
LogDebug(BCLog::NET, "peer %d requested invalid block hash: %s\n",
|
LogDebug(BCLog::NET, "peer requested invalid block hash: %s, %s\n",
|
||||||
node.GetId(), stop_hash.ToString());
|
stop_hash.ToString(), node.DisconnectMsg(fLogIPs));
|
||||||
node.fDisconnect = true;
|
node.fDisconnect = true;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -3132,15 +3132,15 @@ bool PeerManagerImpl::PrepareBlockFilterRequest(CNode& node, Peer& peer,
|
||||||
|
|
||||||
uint32_t stop_height = stop_index->nHeight;
|
uint32_t stop_height = stop_index->nHeight;
|
||||||
if (start_height > stop_height) {
|
if (start_height > stop_height) {
|
||||||
LogDebug(BCLog::NET, "peer %d sent invalid getcfilters/getcfheaders with "
|
LogDebug(BCLog::NET, "peer sent invalid getcfilters/getcfheaders with "
|
||||||
"start height %d and stop height %d\n",
|
"start height %d and stop height %d, %s\n",
|
||||||
node.GetId(), start_height, stop_height);
|
start_height, stop_height, node.DisconnectMsg(fLogIPs));
|
||||||
node.fDisconnect = true;
|
node.fDisconnect = true;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
if (stop_height - start_height >= max_height_diff) {
|
if (stop_height - start_height >= max_height_diff) {
|
||||||
LogDebug(BCLog::NET, "peer %d requested too many cfilters/cfheaders: %d / %d\n",
|
LogDebug(BCLog::NET, "peer requested too many cfilters/cfheaders: %d / %d, %s\n",
|
||||||
node.GetId(), stop_height - start_height + 1, max_height_diff);
|
stop_height - start_height + 1, max_height_diff, node.DisconnectMsg(fLogIPs));
|
||||||
node.fDisconnect = true;
|
node.fDisconnect = true;
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
@ -3407,14 +3407,17 @@ void PeerManagerImpl::ProcessMessage(CNode& pfrom, const std::string& msg_type,
|
||||||
}
|
}
|
||||||
if (pfrom.ExpectServicesFromConn() && !HasAllDesirableServiceFlags(nServices))
|
if (pfrom.ExpectServicesFromConn() && !HasAllDesirableServiceFlags(nServices))
|
||||||
{
|
{
|
||||||
LogDebug(BCLog::NET, "peer=%d does not offer the expected services (%08x offered, %08x expected); disconnecting\n", pfrom.GetId(), nServices, GetDesirableServiceFlags(nServices));
|
LogDebug(BCLog::NET, "peer does not offer the expected services (%08x offered, %08x expected), %s\n",
|
||||||
|
nServices,
|
||||||
|
GetDesirableServiceFlags(nServices),
|
||||||
|
pfrom.DisconnectMsg(fLogIPs));
|
||||||
pfrom.fDisconnect = true;
|
pfrom.fDisconnect = true;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (nVersion < MIN_PEER_PROTO_VERSION) {
|
if (nVersion < MIN_PEER_PROTO_VERSION) {
|
||||||
// disconnect from peers older than this proto version
|
// disconnect from peers older than this proto version
|
||||||
LogDebug(BCLog::NET, "peer=%d using obsolete version %i; disconnecting\n", pfrom.GetId(), nVersion);
|
LogDebug(BCLog::NET, "peer using obsolete version %i, %s\n", nVersion, pfrom.DisconnectMsg(fLogIPs));
|
||||||
pfrom.fDisconnect = true;
|
pfrom.fDisconnect = true;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -3565,15 +3568,11 @@ void PeerManagerImpl::ProcessMessage(CNode& pfrom, const std::string& msg_type,
|
||||||
m_addrman.Good(pfrom.addr);
|
m_addrman.Good(pfrom.addr);
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string remoteAddr;
|
|
||||||
if (fLogIPs)
|
|
||||||
remoteAddr = ", peeraddr=" + pfrom.addr.ToStringAddrPort();
|
|
||||||
|
|
||||||
const auto mapped_as{m_connman.GetMappedAS(pfrom.addr)};
|
const auto mapped_as{m_connman.GetMappedAS(pfrom.addr)};
|
||||||
LogDebug(BCLog::NET, "receive version message: %s: version %d, blocks=%d, us=%s, txrelay=%d, peer=%d%s%s\n",
|
LogDebug(BCLog::NET, "receive version message: %s: version %d, blocks=%d, us=%s, txrelay=%d, peer=%d%s%s\n",
|
||||||
cleanSubVer, pfrom.nVersion,
|
cleanSubVer, pfrom.nVersion,
|
||||||
peer->m_starting_height, addrMe.ToStringAddrPort(), fRelay, pfrom.GetId(),
|
peer->m_starting_height, addrMe.ToStringAddrPort(), fRelay, pfrom.GetId(),
|
||||||
remoteAddr, (mapped_as ? strprintf(", mapped_as=%d", mapped_as) : ""));
|
pfrom.LogIP(fLogIPs), (mapped_as ? strprintf(", mapped_as=%d", mapped_as) : ""));
|
||||||
|
|
||||||
peer->m_time_offset = NodeSeconds{std::chrono::seconds{nTime}} - Now<NodeSeconds>();
|
peer->m_time_offset = NodeSeconds{std::chrono::seconds{nTime}} - Now<NodeSeconds>();
|
||||||
if (!pfrom.IsInboundConn()) {
|
if (!pfrom.IsInboundConn()) {
|
||||||
|
@ -3591,7 +3590,7 @@ void PeerManagerImpl::ProcessMessage(CNode& pfrom, const std::string& msg_type,
|
||||||
|
|
||||||
// Feeler connections exist only to verify if address is online.
|
// Feeler connections exist only to verify if address is online.
|
||||||
if (pfrom.IsFeelerConn()) {
|
if (pfrom.IsFeelerConn()) {
|
||||||
LogDebug(BCLog::NET, "feeler connection completed peer=%d; disconnecting\n", pfrom.GetId());
|
LogDebug(BCLog::NET, "feeler connection completed, %s\n", pfrom.DisconnectMsg(fLogIPs));
|
||||||
pfrom.fDisconnect = true;
|
pfrom.fDisconnect = true;
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
|
@ -3617,7 +3616,7 @@ void PeerManagerImpl::ProcessMessage(CNode& pfrom, const std::string& msg_type,
|
||||||
pfrom.ConnectionTypeAsString(),
|
pfrom.ConnectionTypeAsString(),
|
||||||
TransportTypeAsString(pfrom.m_transport->GetInfo().transport_type),
|
TransportTypeAsString(pfrom.m_transport->GetInfo().transport_type),
|
||||||
pfrom.nVersion.load(), peer->m_starting_height,
|
pfrom.nVersion.load(), peer->m_starting_height,
|
||||||
pfrom.GetId(), (fLogIPs ? strprintf(", peeraddr=%s", pfrom.addr.ToStringAddrPort()) : ""),
|
pfrom.GetId(), pfrom.LogIP(fLogIPs),
|
||||||
(mapped_as ? strprintf(", mapped_as=%d", mapped_as) : ""));
|
(mapped_as ? strprintf(", mapped_as=%d", mapped_as) : ""));
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -3695,7 +3694,7 @@ void PeerManagerImpl::ProcessMessage(CNode& pfrom, const std::string& msg_type,
|
||||||
if (msg_type == NetMsgType::WTXIDRELAY) {
|
if (msg_type == NetMsgType::WTXIDRELAY) {
|
||||||
if (pfrom.fSuccessfullyConnected) {
|
if (pfrom.fSuccessfullyConnected) {
|
||||||
// Disconnect peers that send a wtxidrelay message after VERACK.
|
// Disconnect peers that send a wtxidrelay message after VERACK.
|
||||||
LogDebug(BCLog::NET, "wtxidrelay received after verack from peer=%d; disconnecting\n", pfrom.GetId());
|
LogDebug(BCLog::NET, "wtxidrelay received after verack, %s\n", pfrom.DisconnectMsg(fLogIPs));
|
||||||
pfrom.fDisconnect = true;
|
pfrom.fDisconnect = true;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -3717,7 +3716,7 @@ void PeerManagerImpl::ProcessMessage(CNode& pfrom, const std::string& msg_type,
|
||||||
if (msg_type == NetMsgType::SENDADDRV2) {
|
if (msg_type == NetMsgType::SENDADDRV2) {
|
||||||
if (pfrom.fSuccessfullyConnected) {
|
if (pfrom.fSuccessfullyConnected) {
|
||||||
// Disconnect peers that send a SENDADDRV2 message after VERACK.
|
// Disconnect peers that send a SENDADDRV2 message after VERACK.
|
||||||
LogDebug(BCLog::NET, "sendaddrv2 received after verack from peer=%d; disconnecting\n", pfrom.GetId());
|
LogDebug(BCLog::NET, "sendaddrv2 received after verack, %s\n", pfrom.DisconnectMsg(fLogIPs));
|
||||||
pfrom.fDisconnect = true;
|
pfrom.fDisconnect = true;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -3730,19 +3729,19 @@ void PeerManagerImpl::ProcessMessage(CNode& pfrom, const std::string& msg_type,
|
||||||
// from switching announcement protocols after the connection is up.
|
// from switching announcement protocols after the connection is up.
|
||||||
if (msg_type == NetMsgType::SENDTXRCNCL) {
|
if (msg_type == NetMsgType::SENDTXRCNCL) {
|
||||||
if (!m_txreconciliation) {
|
if (!m_txreconciliation) {
|
||||||
LogPrintLevel(BCLog::NET, BCLog::Level::Debug, "sendtxrcncl from peer=%d ignored, as our node does not have txreconciliation enabled\n", pfrom.GetId());
|
LogDebug(BCLog::NET, "sendtxrcncl from peer=%d ignored, as our node does not have txreconciliation enabled\n", pfrom.GetId());
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (pfrom.fSuccessfullyConnected) {
|
if (pfrom.fSuccessfullyConnected) {
|
||||||
LogPrintLevel(BCLog::NET, BCLog::Level::Debug, "sendtxrcncl received after verack from peer=%d; disconnecting\n", pfrom.GetId());
|
LogDebug(BCLog::NET, "sendtxrcncl received after verack, %s\n", pfrom.DisconnectMsg(fLogIPs));
|
||||||
pfrom.fDisconnect = true;
|
pfrom.fDisconnect = true;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
// Peer must not offer us reconciliations if we specified no tx relay support in VERSION.
|
// Peer must not offer us reconciliations if we specified no tx relay support in VERSION.
|
||||||
if (RejectIncomingTxs(pfrom)) {
|
if (RejectIncomingTxs(pfrom)) {
|
||||||
LogPrintLevel(BCLog::NET, BCLog::Level::Debug, "sendtxrcncl received from peer=%d to which we indicated no tx relay; disconnecting\n", pfrom.GetId());
|
LogDebug(BCLog::NET, "sendtxrcncl received to which we indicated no tx relay, %s\n", pfrom.DisconnectMsg(fLogIPs));
|
||||||
pfrom.fDisconnect = true;
|
pfrom.fDisconnect = true;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -3752,7 +3751,7 @@ void PeerManagerImpl::ProcessMessage(CNode& pfrom, const std::string& msg_type,
|
||||||
// eliminates them, so that this flag fully represents what we are looking for.
|
// eliminates them, so that this flag fully represents what we are looking for.
|
||||||
const auto* tx_relay = peer->GetTxRelay();
|
const auto* tx_relay = peer->GetTxRelay();
|
||||||
if (!tx_relay || !WITH_LOCK(tx_relay->m_bloom_filter_mutex, return tx_relay->m_relay_txs)) {
|
if (!tx_relay || !WITH_LOCK(tx_relay->m_bloom_filter_mutex, return tx_relay->m_relay_txs)) {
|
||||||
LogPrintLevel(BCLog::NET, BCLog::Level::Debug, "sendtxrcncl received from peer=%d which indicated no tx relay to us; disconnecting\n", pfrom.GetId());
|
LogDebug(BCLog::NET, "sendtxrcncl received which indicated no tx relay to us, %s\n", pfrom.DisconnectMsg(fLogIPs));
|
||||||
pfrom.fDisconnect = true;
|
pfrom.fDisconnect = true;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -3765,16 +3764,16 @@ void PeerManagerImpl::ProcessMessage(CNode& pfrom, const std::string& msg_type,
|
||||||
peer_txreconcl_version, remote_salt);
|
peer_txreconcl_version, remote_salt);
|
||||||
switch (result) {
|
switch (result) {
|
||||||
case ReconciliationRegisterResult::NOT_FOUND:
|
case ReconciliationRegisterResult::NOT_FOUND:
|
||||||
LogPrintLevel(BCLog::NET, BCLog::Level::Debug, "Ignore unexpected txreconciliation signal from peer=%d\n", pfrom.GetId());
|
LogDebug(BCLog::NET, "Ignore unexpected txreconciliation signal from peer=%d\n", pfrom.GetId());
|
||||||
break;
|
break;
|
||||||
case ReconciliationRegisterResult::SUCCESS:
|
case ReconciliationRegisterResult::SUCCESS:
|
||||||
break;
|
break;
|
||||||
case ReconciliationRegisterResult::ALREADY_REGISTERED:
|
case ReconciliationRegisterResult::ALREADY_REGISTERED:
|
||||||
LogPrintLevel(BCLog::NET, BCLog::Level::Debug, "txreconciliation protocol violation from peer=%d (sendtxrcncl received from already registered peer); disconnecting\n", pfrom.GetId());
|
LogDebug(BCLog::NET, "txreconciliation protocol violation (sendtxrcncl received from already registered peer), %s\n", pfrom.DisconnectMsg(fLogIPs));
|
||||||
pfrom.fDisconnect = true;
|
pfrom.fDisconnect = true;
|
||||||
return;
|
return;
|
||||||
case ReconciliationRegisterResult::PROTOCOL_VIOLATION:
|
case ReconciliationRegisterResult::PROTOCOL_VIOLATION:
|
||||||
LogPrintLevel(BCLog::NET, BCLog::Level::Debug, "txreconciliation protocol violation from peer=%d; disconnecting\n", pfrom.GetId());
|
LogDebug(BCLog::NET, "txreconciliation protocol violation, %s\n", pfrom.DisconnectMsg(fLogIPs));
|
||||||
pfrom.fDisconnect = true;
|
pfrom.fDisconnect = true;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -3877,7 +3876,7 @@ void PeerManagerImpl::ProcessMessage(CNode& pfrom, const std::string& msg_type,
|
||||||
|
|
||||||
// AddrFetch: Require multiple addresses to avoid disconnecting on self-announcements
|
// AddrFetch: Require multiple addresses to avoid disconnecting on self-announcements
|
||||||
if (pfrom.IsAddrFetchConn() && vAddr.size() > 1) {
|
if (pfrom.IsAddrFetchConn() && vAddr.size() > 1) {
|
||||||
LogDebug(BCLog::NET, "addrfetch connection completed peer=%d; disconnecting\n", pfrom.GetId());
|
LogDebug(BCLog::NET, "addrfetch connection completed, %s\n", pfrom.DisconnectMsg(fLogIPs));
|
||||||
pfrom.fDisconnect = true;
|
pfrom.fDisconnect = true;
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
|
@ -3927,7 +3926,7 @@ void PeerManagerImpl::ProcessMessage(CNode& pfrom, const std::string& msg_type,
|
||||||
}
|
}
|
||||||
} else if (inv.IsGenTxMsg()) {
|
} else if (inv.IsGenTxMsg()) {
|
||||||
if (reject_tx_invs) {
|
if (reject_tx_invs) {
|
||||||
LogDebug(BCLog::NET, "transaction (%s) inv sent in violation of protocol, disconnecting peer=%d\n", inv.hash.ToString(), pfrom.GetId());
|
LogDebug(BCLog::NET, "transaction (%s) inv sent in violation of protocol, %s\n", inv.hash.ToString(), pfrom.DisconnectMsg(fLogIPs));
|
||||||
pfrom.fDisconnect = true;
|
pfrom.fDisconnect = true;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -4004,7 +4003,7 @@ void PeerManagerImpl::ProcessMessage(CNode& pfrom, const std::string& msg_type,
|
||||||
vRecv >> locator >> hashStop;
|
vRecv >> locator >> hashStop;
|
||||||
|
|
||||||
if (locator.vHave.size() > MAX_LOCATOR_SZ) {
|
if (locator.vHave.size() > MAX_LOCATOR_SZ) {
|
||||||
LogDebug(BCLog::NET, "getblocks locator size %lld > %d, disconnect peer=%d\n", locator.vHave.size(), MAX_LOCATOR_SZ, pfrom.GetId());
|
LogDebug(BCLog::NET, "getblocks locator size %lld > %d, %s\n", locator.vHave.size(), MAX_LOCATOR_SZ, pfrom.DisconnectMsg(fLogIPs));
|
||||||
pfrom.fDisconnect = true;
|
pfrom.fDisconnect = true;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -4126,7 +4125,7 @@ void PeerManagerImpl::ProcessMessage(CNode& pfrom, const std::string& msg_type,
|
||||||
vRecv >> locator >> hashStop;
|
vRecv >> locator >> hashStop;
|
||||||
|
|
||||||
if (locator.vHave.size() > MAX_LOCATOR_SZ) {
|
if (locator.vHave.size() > MAX_LOCATOR_SZ) {
|
||||||
LogDebug(BCLog::NET, "getheaders locator size %lld > %d, disconnect peer=%d\n", locator.vHave.size(), MAX_LOCATOR_SZ, pfrom.GetId());
|
LogDebug(BCLog::NET, "getheaders locator size %lld > %d, %s\n", locator.vHave.size(), MAX_LOCATOR_SZ, pfrom.DisconnectMsg(fLogIPs));
|
||||||
pfrom.fDisconnect = true;
|
pfrom.fDisconnect = true;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -4667,7 +4666,7 @@ void PeerManagerImpl::ProcessMessage(CNode& pfrom, const std::string& msg_type,
|
||||||
{
|
{
|
||||||
if (!pfrom.HasPermission(NetPermissionFlags::NoBan))
|
if (!pfrom.HasPermission(NetPermissionFlags::NoBan))
|
||||||
{
|
{
|
||||||
LogDebug(BCLog::NET, "mempool request with bloom filters disabled, disconnect peer=%d\n", pfrom.GetId());
|
LogDebug(BCLog::NET, "mempool request with bloom filters disabled, %s\n", pfrom.DisconnectMsg(fLogIPs));
|
||||||
pfrom.fDisconnect = true;
|
pfrom.fDisconnect = true;
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
|
@ -4677,7 +4676,7 @@ void PeerManagerImpl::ProcessMessage(CNode& pfrom, const std::string& msg_type,
|
||||||
{
|
{
|
||||||
if (!pfrom.HasPermission(NetPermissionFlags::NoBan))
|
if (!pfrom.HasPermission(NetPermissionFlags::NoBan))
|
||||||
{
|
{
|
||||||
LogDebug(BCLog::NET, "mempool request with bandwidth limit reached, disconnect peer=%d\n", pfrom.GetId());
|
LogDebug(BCLog::NET, "mempool request with bandwidth limit reached, %s\n", pfrom.DisconnectMsg(fLogIPs));
|
||||||
pfrom.fDisconnect = true;
|
pfrom.fDisconnect = true;
|
||||||
}
|
}
|
||||||
return;
|
return;
|
||||||
|
@ -4767,7 +4766,7 @@ void PeerManagerImpl::ProcessMessage(CNode& pfrom, const std::string& msg_type,
|
||||||
|
|
||||||
if (msg_type == NetMsgType::FILTERLOAD) {
|
if (msg_type == NetMsgType::FILTERLOAD) {
|
||||||
if (!(peer->m_our_services & NODE_BLOOM)) {
|
if (!(peer->m_our_services & NODE_BLOOM)) {
|
||||||
LogDebug(BCLog::NET, "filterload received despite not offering bloom services from peer=%d; disconnecting\n", pfrom.GetId());
|
LogDebug(BCLog::NET, "filterload received despite not offering bloom services, %s\n", pfrom.DisconnectMsg(fLogIPs));
|
||||||
pfrom.fDisconnect = true;
|
pfrom.fDisconnect = true;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -4792,7 +4791,7 @@ void PeerManagerImpl::ProcessMessage(CNode& pfrom, const std::string& msg_type,
|
||||||
|
|
||||||
if (msg_type == NetMsgType::FILTERADD) {
|
if (msg_type == NetMsgType::FILTERADD) {
|
||||||
if (!(peer->m_our_services & NODE_BLOOM)) {
|
if (!(peer->m_our_services & NODE_BLOOM)) {
|
||||||
LogDebug(BCLog::NET, "filteradd received despite not offering bloom services from peer=%d; disconnecting\n", pfrom.GetId());
|
LogDebug(BCLog::NET, "filteradd received despite not offering bloom services, %s\n", pfrom.DisconnectMsg(fLogIPs));
|
||||||
pfrom.fDisconnect = true;
|
pfrom.fDisconnect = true;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -4820,7 +4819,7 @@ void PeerManagerImpl::ProcessMessage(CNode& pfrom, const std::string& msg_type,
|
||||||
|
|
||||||
if (msg_type == NetMsgType::FILTERCLEAR) {
|
if (msg_type == NetMsgType::FILTERCLEAR) {
|
||||||
if (!(peer->m_our_services & NODE_BLOOM)) {
|
if (!(peer->m_our_services & NODE_BLOOM)) {
|
||||||
LogDebug(BCLog::NET, "filterclear received despite not offering bloom services from peer=%d; disconnecting\n", pfrom.GetId());
|
LogDebug(BCLog::NET, "filterclear received despite not offering bloom services, %s\n", pfrom.DisconnectMsg(fLogIPs));
|
||||||
pfrom.fDisconnect = true;
|
pfrom.fDisconnect = true;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -5041,7 +5040,7 @@ void PeerManagerImpl::ConsiderEviction(CNode& pto, Peer& peer, std::chrono::seco
|
||||||
// message to give the peer a chance to update us.
|
// message to give the peer a chance to update us.
|
||||||
if (state.m_chain_sync.m_sent_getheaders) {
|
if (state.m_chain_sync.m_sent_getheaders) {
|
||||||
// They've run out of time to catch up!
|
// They've run out of time to catch up!
|
||||||
LogPrintf("Disconnecting outbound peer %d for old chain, best known block = %s\n", pto.GetId(), state.pindexBestKnownBlock != nullptr ? state.pindexBestKnownBlock->GetBlockHash().ToString() : "<none>");
|
LogInfo("Outbound peer has old chain, best known block = %s, %s\n", state.pindexBestKnownBlock != nullptr ? state.pindexBestKnownBlock->GetBlockHash().ToString() : "<none>", pto.DisconnectMsg(fLogIPs));
|
||||||
pto.fDisconnect = true;
|
pto.fDisconnect = true;
|
||||||
} else {
|
} else {
|
||||||
assert(state.m_chain_sync.m_work_header);
|
assert(state.m_chain_sync.m_work_header);
|
||||||
|
@ -5442,7 +5441,7 @@ bool PeerManagerImpl::SendMessages(CNode* pto)
|
||||||
const auto current_time{GetTime<std::chrono::microseconds>()};
|
const auto current_time{GetTime<std::chrono::microseconds>()};
|
||||||
|
|
||||||
if (pto->IsAddrFetchConn() && current_time - pto->m_connected > 10 * AVG_ADDRESS_BROADCAST_INTERVAL) {
|
if (pto->IsAddrFetchConn() && current_time - pto->m_connected > 10 * AVG_ADDRESS_BROADCAST_INTERVAL) {
|
||||||
LogDebug(BCLog::NET, "addrfetch connection timeout; disconnecting peer=%d\n", pto->GetId());
|
LogDebug(BCLog::NET, "addrfetch connection timeout, %s\n", pto->DisconnectMsg(fLogIPs));
|
||||||
pto->fDisconnect = true;
|
pto->fDisconnect = true;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -5786,7 +5785,7 @@ bool PeerManagerImpl::SendMessages(CNode* pto)
|
||||||
// Stalling only triggers when the block download window cannot move. During normal steady state,
|
// Stalling only triggers when the block download window cannot move. During normal steady state,
|
||||||
// the download window should be much larger than the to-be-downloaded set of blocks, so disconnection
|
// the download window should be much larger than the to-be-downloaded set of blocks, so disconnection
|
||||||
// should only happen during initial block download.
|
// should only happen during initial block download.
|
||||||
LogPrintf("Peer=%d%s is stalling block download, disconnecting\n", pto->GetId(), fLogIPs ? strprintf(" peeraddr=%s", pto->addr.ToStringAddrPort()) : "");
|
LogInfo("Peer is stalling block download, %s\n", pto->DisconnectMsg(fLogIPs));
|
||||||
pto->fDisconnect = true;
|
pto->fDisconnect = true;
|
||||||
// Increase timeout for the next peer so that we don't disconnect multiple peers if our own
|
// Increase timeout for the next peer so that we don't disconnect multiple peers if our own
|
||||||
// bandwidth is insufficient.
|
// bandwidth is insufficient.
|
||||||
|
@ -5805,7 +5804,7 @@ bool PeerManagerImpl::SendMessages(CNode* pto)
|
||||||
QueuedBlock &queuedBlock = state.vBlocksInFlight.front();
|
QueuedBlock &queuedBlock = state.vBlocksInFlight.front();
|
||||||
int nOtherPeersWithValidatedDownloads = m_peers_downloading_from - 1;
|
int nOtherPeersWithValidatedDownloads = m_peers_downloading_from - 1;
|
||||||
if (current_time > state.m_downloading_since + std::chrono::seconds{consensusParams.nPowTargetSpacing} * (BLOCK_DOWNLOAD_TIMEOUT_BASE + BLOCK_DOWNLOAD_TIMEOUT_PER_PEER * nOtherPeersWithValidatedDownloads)) {
|
if (current_time > state.m_downloading_since + std::chrono::seconds{consensusParams.nPowTargetSpacing} * (BLOCK_DOWNLOAD_TIMEOUT_BASE + BLOCK_DOWNLOAD_TIMEOUT_PER_PEER * nOtherPeersWithValidatedDownloads)) {
|
||||||
LogPrintf("Timeout downloading block %s from peer=%d%s, disconnecting\n", queuedBlock.pindex->GetBlockHash().ToString(), pto->GetId(), fLogIPs ? strprintf(" peeraddr=%s", pto->addr.ToStringAddrPort()) : "");
|
LogInfo("Timeout downloading block %s, %s\n", queuedBlock.pindex->GetBlockHash().ToString(), pto->DisconnectMsg(fLogIPs));
|
||||||
pto->fDisconnect = true;
|
pto->fDisconnect = true;
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -5821,11 +5820,11 @@ bool PeerManagerImpl::SendMessages(CNode* pto)
|
||||||
// disconnect our sync peer for stalling; we have bigger
|
// disconnect our sync peer for stalling; we have bigger
|
||||||
// problems if we can't get any outbound peers.
|
// problems if we can't get any outbound peers.
|
||||||
if (!pto->HasPermission(NetPermissionFlags::NoBan)) {
|
if (!pto->HasPermission(NetPermissionFlags::NoBan)) {
|
||||||
LogPrintf("Timeout downloading headers from peer=%d%s, disconnecting\n", pto->GetId(), fLogIPs ? strprintf(" peeraddr=%s", pto->addr.ToStringAddrPort()) : "");
|
LogInfo("Timeout downloading headers, %s\n", pto->DisconnectMsg(fLogIPs));
|
||||||
pto->fDisconnect = true;
|
pto->fDisconnect = true;
|
||||||
return true;
|
return true;
|
||||||
} else {
|
} else {
|
||||||
LogPrintf("Timeout downloading headers from noban peer=%d%s, not disconnecting\n", pto->GetId(), fLogIPs ? strprintf(" peeraddr=%s", pto->addr.ToStringAddrPort()) : "");
|
LogInfo("Timeout downloading headers from noban peer, not %s\n", pto->DisconnectMsg(fLogIPs));
|
||||||
// Reset the headers sync state so that we have a
|
// Reset the headers sync state so that we have a
|
||||||
// chance to try downloading from a different peer.
|
// chance to try downloading from a different peer.
|
||||||
// Note: this will also result in at least one more
|
// Note: this will also result in at least one more
|
||||||
|
|
|
@ -122,7 +122,7 @@ class MaxUploadTest(BitcoinTestFramework):
|
||||||
assert_equal(len(self.nodes[0].getpeerinfo()), 3)
|
assert_equal(len(self.nodes[0].getpeerinfo()), 3)
|
||||||
# At most a couple more tries should succeed (depending on how long
|
# At most a couple more tries should succeed (depending on how long
|
||||||
# the test has been running so far).
|
# the test has been running so far).
|
||||||
with self.nodes[0].assert_debug_log(expected_msgs=["historical block serving limit reached, disconnect peer"]):
|
with self.nodes[0].assert_debug_log(expected_msgs=["historical block serving limit reached, disconnecting peer=0"]):
|
||||||
for _ in range(3):
|
for _ in range(3):
|
||||||
p2p_conns[0].send_message(getdata_request)
|
p2p_conns[0].send_message(getdata_request)
|
||||||
p2p_conns[0].wait_for_disconnect()
|
p2p_conns[0].wait_for_disconnect()
|
||||||
|
@ -147,7 +147,7 @@ class MaxUploadTest(BitcoinTestFramework):
|
||||||
|
|
||||||
# But if p2p_conns[1] tries for an old block, it gets disconnected too.
|
# But if p2p_conns[1] tries for an old block, it gets disconnected too.
|
||||||
getdata_request.inv = [CInv(MSG_BLOCK, big_old_block)]
|
getdata_request.inv = [CInv(MSG_BLOCK, big_old_block)]
|
||||||
with self.nodes[0].assert_debug_log(expected_msgs=["historical block serving limit reached, disconnect peer"]):
|
with self.nodes[0].assert_debug_log(expected_msgs=["historical block serving limit reached, disconnecting peer=1"]):
|
||||||
p2p_conns[1].send_message(getdata_request)
|
p2p_conns[1].send_message(getdata_request)
|
||||||
p2p_conns[1].wait_for_disconnect()
|
p2p_conns[1].wait_for_disconnect()
|
||||||
assert_equal(len(self.nodes[0].getpeerinfo()), 1)
|
assert_equal(len(self.nodes[0].getpeerinfo()), 1)
|
||||||
|
@ -197,7 +197,7 @@ class MaxUploadTest(BitcoinTestFramework):
|
||||||
assert_equal(peer_info[0]['permissions'], ['download'])
|
assert_equal(peer_info[0]['permissions'], ['download'])
|
||||||
|
|
||||||
self.log.info("Peer gets disconnected for a mempool request after limit is reached")
|
self.log.info("Peer gets disconnected for a mempool request after limit is reached")
|
||||||
with self.nodes[0].assert_debug_log(expected_msgs=["mempool request with bandwidth limit reached, disconnect peer"]):
|
with self.nodes[0].assert_debug_log(expected_msgs=["mempool request with bandwidth limit reached, disconnecting peer=0"]):
|
||||||
peer.send_message(msg_mempool())
|
peer.send_message(msg_mempool())
|
||||||
peer.wait_for_disconnect()
|
peer.wait_for_disconnect()
|
||||||
|
|
||||||
|
|
|
@ -78,7 +78,7 @@ class AddrTest(BitcoinTestFramework):
|
||||||
def run_test(self):
|
def run_test(self):
|
||||||
self.log.info('Check disconnection when sending sendaddrv2 after verack')
|
self.log.info('Check disconnection when sending sendaddrv2 after verack')
|
||||||
conn = self.nodes[0].add_p2p_connection(P2PInterface())
|
conn = self.nodes[0].add_p2p_connection(P2PInterface())
|
||||||
with self.nodes[0].assert_debug_log(['sendaddrv2 received after verack from peer=0; disconnecting']):
|
with self.nodes[0].assert_debug_log(['sendaddrv2 received after verack, disconnecting peer=0']):
|
||||||
conn.send_message(msg_sendaddrv2())
|
conn.send_message(msg_sendaddrv2())
|
||||||
conn.wait_for_disconnect()
|
conn.wait_for_disconnect()
|
||||||
|
|
||||||
|
|
|
@ -172,7 +172,7 @@ class P2PLeakTest(BitcoinTestFramework):
|
||||||
|
|
||||||
self.log.info('Check that old peers are disconnected')
|
self.log.info('Check that old peers are disconnected')
|
||||||
p2p_old_peer = self.nodes[0].add_p2p_connection(P2PInterface(), send_version=False, wait_for_verack=False)
|
p2p_old_peer = self.nodes[0].add_p2p_connection(P2PInterface(), send_version=False, wait_for_verack=False)
|
||||||
with self.nodes[0].assert_debug_log(["using obsolete version 31799; disconnecting"]):
|
with self.nodes[0].assert_debug_log(["using obsolete version 31799, disconnecting peer=5"]):
|
||||||
p2p_old_peer.send_message(self.create_old_version(31799))
|
p2p_old_peer.send_message(self.create_old_version(31799))
|
||||||
p2p_old_peer.wait_for_disconnect()
|
p2p_old_peer.wait_for_disconnect()
|
||||||
|
|
||||||
|
|
|
@ -168,7 +168,7 @@ class SendTxRcnclTest(BitcoinTestFramework):
|
||||||
with self.nodes[0].assert_debug_log(["received: sendtxrcncl"]):
|
with self.nodes[0].assert_debug_log(["received: sendtxrcncl"]):
|
||||||
peer.send_message(create_sendtxrcncl_msg())
|
peer.send_message(create_sendtxrcncl_msg())
|
||||||
self.log.info('second SENDTXRCNCL triggers a disconnect')
|
self.log.info('second SENDTXRCNCL triggers a disconnect')
|
||||||
with self.nodes[0].assert_debug_log(["(sendtxrcncl received from already registered peer); disconnecting"]):
|
with self.nodes[0].assert_debug_log(["(sendtxrcncl received from already registered peer), disconnecting peer=0"]):
|
||||||
peer.send_message(create_sendtxrcncl_msg())
|
peer.send_message(create_sendtxrcncl_msg())
|
||||||
peer.wait_for_disconnect()
|
peer.wait_for_disconnect()
|
||||||
|
|
||||||
|
@ -226,7 +226,7 @@ class SendTxRcnclTest(BitcoinTestFramework):
|
||||||
self.log.info('SENDTXRCNCL if block-relay-only triggers a disconnect')
|
self.log.info('SENDTXRCNCL if block-relay-only triggers a disconnect')
|
||||||
peer = self.nodes[0].add_outbound_p2p_connection(
|
peer = self.nodes[0].add_outbound_p2p_connection(
|
||||||
PeerNoVerack(), wait_for_verack=False, p2p_idx=0, connection_type="block-relay-only")
|
PeerNoVerack(), wait_for_verack=False, p2p_idx=0, connection_type="block-relay-only")
|
||||||
with self.nodes[0].assert_debug_log(["we indicated no tx relay; disconnecting"]):
|
with self.nodes[0].assert_debug_log(["we indicated no tx relay, disconnecting peer=5"]):
|
||||||
peer.send_message(create_sendtxrcncl_msg())
|
peer.send_message(create_sendtxrcncl_msg())
|
||||||
peer.wait_for_disconnect()
|
peer.wait_for_disconnect()
|
||||||
|
|
||||||
|
|
|
@ -84,15 +84,15 @@ class TimeoutsTest(BitcoinTestFramework):
|
||||||
|
|
||||||
if self.options.v2transport:
|
if self.options.v2transport:
|
||||||
expected_timeout_logs = [
|
expected_timeout_logs = [
|
||||||
"version handshake timeout peer=0",
|
"version handshake timeout, disconnecting peer=0",
|
||||||
"version handshake timeout peer=1",
|
"version handshake timeout, disconnecting peer=1",
|
||||||
"version handshake timeout peer=2",
|
"version handshake timeout, disconnecting peer=2",
|
||||||
]
|
]
|
||||||
else:
|
else:
|
||||||
expected_timeout_logs = [
|
expected_timeout_logs = [
|
||||||
"version handshake timeout peer=0",
|
"version handshake timeout, disconnecting peer=0",
|
||||||
"socket no message in first 3 seconds, 1 0 peer=1",
|
"socket no message in first 3 seconds, never sent to peer, disconnecting peer=1",
|
||||||
"socket no message in first 3 seconds, 0 0 peer=2",
|
"socket no message in first 3 seconds, never received from peer, never sent to peer, disconnecting peer=2",
|
||||||
]
|
]
|
||||||
|
|
||||||
with self.nodes[0].assert_debug_log(expected_msgs=expected_timeout_logs):
|
with self.nodes[0].assert_debug_log(expected_msgs=expected_timeout_logs):
|
||||||
|
|
|
@ -151,7 +151,7 @@ class EncryptedP2PMisbehaving(BitcoinTestFramework):
|
||||||
# Ensure that the bytes sent after 4 bytes network magic are actually received.
|
# Ensure that the bytes sent after 4 bytes network magic are actually received.
|
||||||
self.wait_until(lambda: node0.getpeerinfo()[-1]["bytesrecv"] > 4)
|
self.wait_until(lambda: node0.getpeerinfo()[-1]["bytesrecv"] > 4)
|
||||||
self.wait_until(lambda: node0.getpeerinfo()[-1]["bytessent"] > 0)
|
self.wait_until(lambda: node0.getpeerinfo()[-1]["bytessent"] > 0)
|
||||||
with node0.assert_debug_log(['V2 handshake timeout peer=0']):
|
with node0.assert_debug_log(['V2 handshake timeout, disconnecting peer=0']):
|
||||||
node0.bumpmocktime(4) # `InactivityCheck()` triggers now
|
node0.bumpmocktime(4) # `InactivityCheck()` triggers now
|
||||||
peer1.wait_for_disconnect(timeout=1)
|
peer1.wait_for_disconnect(timeout=1)
|
||||||
self.log.info('successful disconnection since modified ellswift was sent as response')
|
self.log.info('successful disconnection since modified ellswift was sent as response')
|
||||||
|
@ -162,7 +162,7 @@ class EncryptedP2PMisbehaving(BitcoinTestFramework):
|
||||||
expected_debug_message = [
|
expected_debug_message = [
|
||||||
[], # EARLY_KEY_RESPONSE
|
[], # EARLY_KEY_RESPONSE
|
||||||
["V2 transport error: missing garbage terminator, peer=1"], # EXCESS_GARBAGE
|
["V2 transport error: missing garbage terminator, peer=1"], # EXCESS_GARBAGE
|
||||||
["V2 handshake timeout peer=3"], # WRONG_GARBAGE_TERMINATOR
|
["V2 handshake timeout, disconnecting peer=3"], # WRONG_GARBAGE_TERMINATOR
|
||||||
["V2 transport error: packet decryption failure"], # WRONG_GARBAGE
|
["V2 transport error: packet decryption failure"], # WRONG_GARBAGE
|
||||||
["V2 transport error: packet decryption failure"], # SEND_NO_AAD
|
["V2 transport error: packet decryption failure"], # SEND_NO_AAD
|
||||||
[], # SEND_NON_EMPTY_VERSION_PACKET
|
[], # SEND_NON_EMPTY_VERSION_PACKET
|
||||||
|
|
Loading…
Reference in a new issue