diff --git a/doc/chain/blocks_and_headers.md b/doc/chain/blocks_and_headers.md new file mode 100644 index 000000000..aeee03df7 --- /dev/null +++ b/doc/chain/blocks_and_headers.md @@ -0,0 +1,38 @@ +# Blocks and Block headers + +## Node receives block from peer (normal operation) + +During normal operation the Grin node will receive blocks from connected peers via the gossip protocol. +If the block and the block header validate successfully then both are saved to the store. The header head is updated to point to the latest block header and the block head is updated to point to the latest block. + +![Simple Block](images/simple_block.png) + +## Node syncs for first time + +[tbd] + +## Node falls behind (sync to catch up with peer) + +Periodically the node will compare its current `total_difficulty` to the `total_difficulty` of all connected peers. If a peer with higher total_difficulty is seen then we attempt to sync to this peer (most_work_peer). If multiple most_work_peers exist then one is selected at random. +The sync process is initiated by building a "locator" based on current known chain state (see [tbd] for more info on the locator) and requesting a list of headers from the peer, passing the locator to help select appropriate headers. +On receiving the list of headers the node will validate them and then save them to the store. For each header the header head will be updated to reflect the most recent header. +The node will then request each "missing" block by comparing the header chain (back from the header head) to the current block chain (back from the block head). Blocks are requested from peers with larger total_difficulty than the node. This process is repeated until no peers are seen with higher total_difficulty and both heads are in a consistent state (pointing to the same head/block). + +![Simple sync](images/simple_sync.png) + +## A new peer connects with a previously unknown longest fork + +![Sync on fork](images/sync_on_fork.png) + +## Node falls significantly behind (>500 blocks) + +Currently we limit header retrieval to batches of approx 500 headers (512?). We need to describe (and think through) exactly what happens when after we receive the first batch of 500 headers such that we have a new header chain but the total_difficulty of this new chain is not sufficient to overtake the existing chain. +What happens here? + +## Node successfully mines a block + +[tbd] + +## Two competing blocks are mined (temporary fork) + +[tbd] diff --git a/doc/chainsync.md b/doc/chain/chain_sync.md similarity index 100% rename from doc/chainsync.md rename to doc/chain/chain_sync.md diff --git a/doc/chain/images/simple_block.png b/doc/chain/images/simple_block.png new file mode 100644 index 000000000..4826cce8c Binary files /dev/null and b/doc/chain/images/simple_block.png differ diff --git a/doc/chain/images/simple_sync.png b/doc/chain/images/simple_sync.png new file mode 100644 index 000000000..42a86e389 Binary files /dev/null and b/doc/chain/images/simple_sync.png differ diff --git a/doc/chain/images/sync_on_fork.png b/doc/chain/images/sync_on_fork.png new file mode 100644 index 000000000..5ea477258 Binary files /dev/null and b/doc/chain/images/sync_on_fork.png differ diff --git a/doc/table_of_contents.md b/doc/table_of_contents.md index a8b4c95fa..710dee630 100644 --- a/doc/table_of_contents.md +++ b/doc/table_of_contents.md @@ -1,7 +1,8 @@ # Documentation structure - [FAQ][faq.md] - Frequently Asked Questions - [build](build.md) - Explaining how to build and run the Grin binaries -- [chainsync](chainsync.md) - About how grin's blockchain is synchronized +- [chain_sync](chain/chain_sync.md) - About how Grin's blockchain is synchronized +- [blocks_and_headers](chain/blocks_and_headers.md) - How Grin tracks blocks and headers on the chain - [contractideas](contractideas.md) - Ideas on how to implement contracts - [grin4bitcoiners](grin4bitcoiners.md) - Explaining grin from a bitcoiner's perspective - [internal/pool](internal/pool.md) - Technical explanation of the transaction pool