Tidy logging, fix bug with stale time in queue

This commit is contained in:
Paul Hauner 2019-03-24 13:06:17 +11:00
parent 6b39c693af
commit 840738ea12
No known key found for this signature in database
GPG Key ID: D362883A9218FCC6
2 changed files with 25 additions and 11 deletions

View File

@ -181,7 +181,7 @@ impl MessageHandler {
_ => panic!("Unknown response: {:?}", response), _ => panic!("Unknown response: {:?}", response),
}; };
debug!(self.log, "RPCResponse"; "type" => response_str); debug!(self.log, "RPCResponse({})", response_str);
} }
} }

View File

@ -13,6 +13,9 @@ use types::{BeaconBlock, BeaconBlockBody, BeaconBlockHeader, Epoch, Hash256, Slo
/// The number of slots that we can import blocks ahead of us, before going into full Sync mode. /// The number of slots that we can import blocks ahead of us, before going into full Sync mode.
const SLOT_IMPORT_TOLERANCE: u64 = 100; const SLOT_IMPORT_TOLERANCE: u64 = 100;
/// The amount of seconds a block (or partial block) may exist in the import queue.
const QUEUE_STALE_SECS: u64 = 60;
/// Keeps track of syncing information for known connected peers. /// Keeps track of syncing information for known connected peers.
#[derive(Clone, Copy, Debug)] #[derive(Clone, Copy, Debug)]
pub struct PeerSyncInfo { pub struct PeerSyncInfo {
@ -103,7 +106,7 @@ impl SimpleSync {
pub fn new(beacon_chain: Arc<BeaconChain>, log: &slog::Logger) -> Self { pub fn new(beacon_chain: Arc<BeaconChain>, log: &slog::Logger) -> Self {
let sync_logger = log.new(o!("Service"=> "Sync")); let sync_logger = log.new(o!("Service"=> "Sync"));
let queue_item_stale_time = Duration::from_secs(600); let queue_item_stale_time = Duration::from_secs(QUEUE_STALE_SECS);
let import_queue = let import_queue =
ImportQueue::new(beacon_chain.clone(), queue_item_stale_time, log.clone()); ImportQueue::new(beacon_chain.clone(), queue_item_stale_time, log.clone());
@ -165,7 +168,11 @@ impl SimpleSync {
match remote_status { match remote_status {
PeerStatus::OnDifferentChain => { PeerStatus::OnDifferentChain => {
debug!(self.log, "Peer is on different chain. Peer: {:?}", peer_id); info!(
self.log, "Failure";
"peer" => format!("{:?}", peer_id),
"reason" => "network_id"
);
network.disconnect(peer_id); network.disconnect(peer_id);
} }
@ -431,8 +438,7 @@ impl SimpleSync {
debug!( debug!(
self.log, self.log,
"RPCRequest"; "RPCRequest(BeaconBlockRoots)";
"type" => "BeaconBlockRoots",
"count" => request.count, "count" => request.count,
"peer" => format!("{:?}", peer_id) "peer" => format!("{:?}", peer_id)
); );
@ -449,8 +455,7 @@ impl SimpleSync {
) { ) {
debug!( debug!(
self.log, self.log,
"RPCRequest"; "RPCRequest(BeaconBlockHeaders)";
"type" => "BeaconBlockHeaders",
"max_headers" => request.max_headers, "max_headers" => request.max_headers,
"peer" => format!("{:?}", peer_id) "peer" => format!("{:?}", peer_id)
); );
@ -466,9 +471,9 @@ impl SimpleSync {
) { ) {
debug!( debug!(
self.log, self.log,
"Requesting {} bodies from {:?}.", "RPCRequest(BeaconBlockBodies)";
request.block_roots.len(), "count" => request.block_roots.len(),
&peer_id "peer" => format!("{:?}", peer_id)
); );
network.send_rpc_request(peer_id.clone(), RPCRequest::BeaconBlockBodies(request)); network.send_rpc_request(peer_id.clone(), RPCRequest::BeaconBlockBodies(request));
@ -510,7 +515,7 @@ impl ImportQueue {
.partials .partials
.iter() .iter()
.filter_map(|(key, partial)| { .filter_map(|(key, partial)| {
if partial.inserted + self.stale_time >= Instant::now() { if partial.inserted + self.stale_time <= Instant::now() {
Some(*key) Some(*key)
} else { } else {
None None
@ -518,6 +523,15 @@ impl ImportQueue {
}) })
.collect(); .collect();
if !keys.is_empty() {
debug!(
self.log,
"ImportQueue removing stale entries";
"stale_count" => keys.len(),
"stale_time_seconds" => self.stale_time.as_secs()
);
}
keys.iter().for_each(|key| { keys.iter().for_each(|key| {
self.partials.remove(&key); self.partials.remove(&key);
}); });