Skip to content

Commit

Permalink
Add Genesis keywords to the glossary
Browse files Browse the repository at this point in the history
  • Loading branch information
nbacquey committed Jul 1, 2024
1 parent 6b44bfb commit 3b72b0a
Showing 1 changed file with 54 additions and 1 deletion.
55 changes: 54 additions & 1 deletion docs/website/contents/for-developers/Glossary.md
Original file line number Diff line number Diff line change
Expand Up @@ -94,6 +94,30 @@ Chain sync is a mini protocol to exchange chains of headers.

- The server can *claim to have no additional headers* when asked for updates. This is signaled explicitly via `MsgAwaitReply` or implicitly by the server's selection tip point that is sent with every message (though the latter is currently not used on the client for any logic).

## :ChainSync Jumping

In the context of [Genesis](#genesis-consensus-protocol-paper-version), a node should execute [ChainSync](#chainsync) with all of its peers, thus often re-downloading and re-validating the same header from multiple peers. This would unnecessarily increase the network load on honest peers, which by definition will serve the same headers on the historical part of the chain.

To mitigate this load, we use ChainSync Jumping, an extended version of ChainSync in which a node only downloads headers from *one* of its peers, and periodically asks all the other peers if they agree with it. If there is a disagreement, ChainSync starts downloading headers from another peer until one of them gets disconnected.

### :Dynamo

The dynamo is the only peer from which a syncing node gets all headers, and run the normal ChainSync protocol. Every once in a while, the syncing node sends a message to all of its jumpers to check if the tip of the dynamo's chain is also on their chain.

### :Jumper

The jumpers are all the peers of a syncing node from which headers aren't downloaded with normal ChainSync protocol. The syncing node will periodically send the tip of its chain to all jumpers. If they confirm this tip is on their chain as well, the node assumes they have the exact same chain as the dynamo, up to their current tip. If they disagree with the tip of the dynamo, they might be promoted to objector.

### :Objector

An objector is a peer which disagrees with the dynamo and from which headers are downloaded. When a jumper doesn't have the tip of the dynamo's chain, it might be promoted to an objector, and exchange headers with the syncing node as per ChainSync protocol. This lasts until either the objector or the dynamo gets disconnected. If the dynamo gets disconnected, a new dynamo is selected by the syncing node.

### :Disengaged Peer

A disengaged peer is a peer from which headers are downloaded as per ChainSync protocol. It cannot be selected as a dynamo, and never becomes a jumper nor an objector.

A dynamo, an objector, or a jumper can be disengaged if they rollback their selection or if they claim to have sent all headers.

## :Checkpointing

Solve dynamic availability by providing syncing nodes with (trusted) information: the points on the (immutable) honest chain every few (i.e. `≤ k`) blocks.
Expand Down Expand Up @@ -165,9 +189,14 @@ When Ouroboros runs as intended, all short forks are short-lived.

## :Forecasting

Forecasting is the ability to validate headers that are ahead of a node's current selection.
Because of [Common Prefix](#common-prefix) and [Chain Growth](#chain-growth), the latest `k+1` ledger states along the node's selection always provide sufficient information for the node to validate its peers' headers that are no more than `3k/f` after the peer's first header.
Since the node hasn't selected that header's block, it has to use forecasting in order to validate its descendant headers.

### :Forecast horizon

The forecast horizon is the number of slots ahead of its current selection in which a node can validate headers. With current Genesis parameters, it is `3k/f`, which is the [stability window](#stability-window) for [Shelley-based eras](#shelley-based-eras).

## :Genesis block

The hypothetical [block](#block) that precedes the first real block, ie the empty [chain](#chain).
Expand All @@ -193,7 +222,7 @@ Disconnect from nodes whose fragments certainly lose to other fragments accordin

Motivation: allows the intersection of candidate fragments to progress

## :Genesis state machine
## :Genesis State Machine (GSM)

Mechanism describing when a node can conclude that it is caught-up. This is used to avoid connecting to lots of ledger peers (for the HAA) when unnecessary and to disarm certain timeouts.

Expand Down Expand Up @@ -330,6 +359,30 @@ Do not select more than `k` blocks past the intersection of all candidate fragme

Motivation: ensure that we can still switch to any candidate chain while respecting the maximum rollback limit.

### :LoE Fragment

The common prefix of all candidate fragments, anchored at the tip of the current chain selection

### :LoE Tip

The tip of the LoE fragment

## :Limit on Patience (LoP)

Disconnect peers that advertise a better header than their current one, but haven't provided it quickly enough.

Motivation: because of the [LoE](#limit-on-eagerness-loe), we don't select headers past `k` blocks beyond the common intersection of all candidate fragments. Therefore, an attacker could prevent a syncing node from making progress by stalling indefinitely at an intersection, promising headers to extend their chain but never delivering them. The LoP mitigates that attack.

In the current version of Genesis, the limit on patience is implemented by a "leaky token bucket" algorithm.

### :Token Capacity (TCAP)

The LoP bucket has an initial and maximal token capacity of `TCAP`. A token is gained when the associated peer sends a header with a higher block number than its previous one. When the bucket is already at maximum capacity, extra tokens are lost.

### :Token Drip Rate (TDRIP)

When the peer has advertised a header with a higher block number than its previous one, but hasn't served yet, the LoP bucket loses tokens at a rate of `TDRIP` tokens per second. When the bucket is empty, the associated peer has exhausted its limit on patience, and gets disconnected.

## :Local root peers

Locally configured peers that the node should know and try to maintain a connection with. These are usually block-producing nodes or relay nodes that SPOs setup in order to shield their block-producing nodes from direct contact.
Expand Down

0 comments on commit 3b72b0a

Please sign in to comment.