broadcast all accepted blocks, main chain or fork (#515) (#517)

tweak logging to be more consistent
This commit is contained in:
AntiochP 2017-12-18 16:18:36 -05:00 committed by GitHub
parent 99186e90f0
commit b37820bd40
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
3 changed files with 39 additions and 10 deletions

View file

@ -157,8 +157,26 @@ impl Chain {
adapter.block_accepted(&b); adapter.block_accepted(&b);
} }
self.check_orphans(); self.check_orphans();
} },
Ok(None) => {} Ok(None) => {
// block got accepted but we did not extend the head
// so its on a fork (or is the start of a new fork)
// broadcast the block out so everyone knows about the fork
//
// TODO - This opens us to an amplification attack on blocks
// mined at a low difficulty. We should suppress really old blocks
// or less relevant blocks somehow.
// We should also probably consider banning nodes that send us really old blocks.
//
if !opts.intersects(SYNC) {
// broadcast the block
let adapter = self.adapter.clone();
adapter.block_accepted(&b);
}
// We accepted a block here so there is a chance we can now accept
// one or more orphans.
self.check_orphans();
},
Err(Error::Orphan) => { Err(Error::Orphan) => {
// TODO - Do we want to check that orphan height is > current height? // TODO - Do we want to check that orphan height is > current height?
// TODO - Just check heights here? Or should we be checking total_difficulty as well? // TODO - Just check heights here? Or should we be checking total_difficulty as well?

View file

@ -50,7 +50,7 @@ pub struct BlockContext {
/// chain head if updated. /// chain head if updated.
pub fn process_block(b: &Block, mut ctx: BlockContext) -> Result<Option<Tip>, Error> { pub fn process_block(b: &Block, mut ctx: BlockContext) -> Result<Option<Tip>, Error> {
// TODO should just take a promise for a block with a full header so we don't // TODO should just take a promise for a block with a full header so we don't
// spend resources reading the full block when its header is invalid // spend resources reading the full block when its header is invalid
debug!( debug!(
LOGGER, LOGGER,
@ -88,7 +88,7 @@ pub fn process_block(b: &Block, mut ctx: BlockContext) -> Result<Option<Tip>, Er
.map_err(|e| Error::StoreErr(e, "pipe reload head".to_owned()))?; .map_err(|e| Error::StoreErr(e, "pipe reload head".to_owned()))?;
// start a chain extension unit of work dependent on the success of the // start a chain extension unit of work dependent on the success of the
// internal validation and saving operations // internal validation and saving operations
sumtree::extending(&mut sumtrees, |mut extension| { sumtree::extending(&mut sumtrees, |mut extension| {
validate_block(b, &mut ctx, &mut extension)?; validate_block(b, &mut ctx, &mut extension)?;
debug!( debug!(
@ -371,8 +371,9 @@ fn update_head(b: &Block, ctx: &mut BlockContext) -> Result<Option<Tip>, Error>
ctx.head = tip.clone(); ctx.head = tip.clone();
debug!( debug!(
LOGGER, LOGGER,
"Updated head to {} at {}.", "pipe: update_head: {}, {} at {}",
b.hash(), b.hash(),
b.header.total_difficulty,
b.header.height b.header.height
); );
if b.header.height % 500 == 0 { if b.header.height % 500 == 0 {
@ -394,8 +395,9 @@ fn update_sync_head(bh: &BlockHeader, ctx: &mut BlockContext) -> Result<Option<T
ctx.head = tip.clone(); ctx.head = tip.clone();
debug!( debug!(
LOGGER, LOGGER,
"pipe: updated sync head to {} at {}.", "pipe: update_sync_head: {}, {} at {}",
bh.hash(), bh.hash(),
bh.total_difficulty,
bh.height, bh.height,
); );
if bh.height % 1000 == 0 { if bh.height % 1000 == 0 {
@ -406,7 +408,7 @@ fn update_sync_head(bh: &BlockHeader, ctx: &mut BlockContext) -> Result<Option<T
fn update_header_head(bh: &BlockHeader, ctx: &mut BlockContext) -> Result<Option<Tip>, Error> { fn update_header_head(bh: &BlockHeader, ctx: &mut BlockContext) -> Result<Option<Tip>, Error> {
let tip = Tip::from_block(bh); let tip = Tip::from_block(bh);
debug!(LOGGER, "pipe: update_header_head {},{}", tip.total_difficulty, ctx.head.total_difficulty); debug!(LOGGER, "pipe: update_header_head: {}, {}", tip.total_difficulty, ctx.head.total_difficulty);
if tip.total_difficulty > ctx.head.total_difficulty { if tip.total_difficulty > ctx.head.total_difficulty {
ctx.store ctx.store
.save_header_head(&tip) .save_header_head(&tip)
@ -414,8 +416,9 @@ fn update_header_head(bh: &BlockHeader, ctx: &mut BlockContext) -> Result<Option
ctx.head = tip.clone(); ctx.head = tip.clone();
debug!( debug!(
LOGGER, LOGGER,
"pipe: updated header head to {} at {}.", "pipe: update_header_head: {}, {} at {}",
bh.hash(), bh.hash(),
bh.total_difficulty,
bh.height, bh.height,
); );
Ok(Some(tip)) Ok(Some(tip))

View file

@ -172,8 +172,9 @@ impl Peers {
/// if it knows the remote peer already has the block. /// if it knows the remote peer already has the block.
pub fn broadcast_block(&self, b: &core::Block) { pub fn broadcast_block(&self, b: &core::Block) {
let peers = self.connected_peers(); let peers = self.connected_peers();
let preferred_peers = 8;
let mut count = 0; let mut count = 0;
for p in peers.iter().take(8) { for p in peers.iter().take(preferred_peers) {
let p = p.read().unwrap(); let p = p.read().unwrap();
if p.is_connected() { if p.is_connected() {
if let Err(e) = p.send_block(b) { if let Err(e) = p.send_block(b) {
@ -183,7 +184,14 @@ impl Peers {
} }
} }
} }
debug!(LOGGER, "Broadcasted block {} to {} peers.", b.header.height, count); debug!(
LOGGER,
"broadcast_block: {}, {} at {}, to {} peers",
b.hash(),
b.header.total_difficulty,
b.header.height,
count,
);
} }
/// Broadcasts the provided transaction to PEER_PREFERRED_COUNT of our peers. /// Broadcasts the provided transaction to PEER_PREFERRED_COUNT of our peers.