Skip to content

Commit

Permalink
Restores accept_span and uses in_scope() instead of enter()
Browse files Browse the repository at this point in the history
  • Loading branch information
arya2 committed Jun 12, 2023
1 parent d18f814 commit 5e0e03a
Showing 1 changed file with 12 additions and 1 deletion.
13 changes: 12 additions & 1 deletion zebra-network/src/peer_set/initialize.rs
Original file line number Diff line number Diff line change
Expand Up @@ -603,9 +603,17 @@ where
);

let connected_addr = peer::ConnectedAddr::new_inbound_direct(addr);
info!(peer = ?connected_addr, "listen_accept");
let accept_span = info_span!("listen_accept", peer = ?connected_addr);
let _guard = accept_span.enter();

debug!("got incoming connection");

// # Correctness
//
// Holding the drop guard returned by Span::enter across .await points will
// result in incorrect traces if the executor yields.
//
// This await is okay because the handshaker's `poll_ready` method always returns Ready.
handshaker.ready().await?;
// TODO: distinguish between proxied listeners and direct listeners
let handshaker_span = info_span!("listen_handshaker", peer = ?connected_addr);
Expand Down Expand Up @@ -637,6 +645,9 @@ where
handshakes.push(Box::pin(handshake_task));
}

// We need to drop the guard before yielding.
std::mem::drop(_guard);

// Rate-limit inbound connection handshakes.
// But sleep longer after a successful connection,
// so we can clear out failed connections at a higher rate.
Expand Down

0 comments on commit 5e0e03a

Please sign in to comment.