mirror of
https://github.com/mimblewimble/grin.git
synced 2025-01-20 19:11:08 +03:00
initial docs and images to describe receiving a block and simple sync. (#405)
* intial docs and images to describe receiving a block and simple sync. * add some more description text * svg -> png * updated simple_sync diagram to include sync_head * rename "block head" -> "body head" * wip - sync_on_form diagram (kill me now) * tidy up diagram for "sync on fork" * consolidate the chain docs
This commit is contained in:
parent
cc9ec53390
commit
d3e5acccf9
6 changed files with 40 additions and 1 deletions
38
doc/chain/blocks_and_headers.md
Normal file
38
doc/chain/blocks_and_headers.md
Normal file
|
@ -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]
|
BIN
doc/chain/images/simple_block.png
Normal file
BIN
doc/chain/images/simple_block.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 44 KiB |
BIN
doc/chain/images/simple_sync.png
Normal file
BIN
doc/chain/images/simple_sync.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 99 KiB |
BIN
doc/chain/images/sync_on_fork.png
Normal file
BIN
doc/chain/images/sync_on_fork.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 109 KiB |
|
@ -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
|
||||
|
|
Loading…
Reference in a new issue