-
Notifications
You must be signed in to change notification settings - Fork 33
Add content to "Introduction" and "Design Goals" sections #1690
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Merged
dnadales
merged 9 commits into
main
from
dnadales/add-content-to-introduction-and-design-goals
Oct 1, 2025
Merged
Changes from all commits
Commits
Show all changes
9 commits
Select commit
Hold shift + click to select a range
dd3afdd
Add contents to explanations/index.md
dnadales 56b81be
Add content to explanations/design_goals.md
dnadales f35eee1
Add instructions on how to get a nix shell with yarn
dnadales e07a73c
Add a glossary entry for the Babbage era
dnadales 620c847
Add a glossary entry for the Byron era
dnadales e6651c3
Add a glossary entry for the HFC
dnadales 6739ea2
Add more content to the glossary entry for Ouroboros Praos
dnadales 1300d9a
Add a glossary entry for PBFT
dnadales bbcdd77
Add a glossary entry for TPraos
dnadales File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -1 +1,63 @@ | ||
| # Design Goals | ||
|
|
||
| The components that make up `ouroboros-consensus` were designed with the following goals in mind. | ||
|
|
||
| ## Multiple Consensus Protocols | ||
|
|
||
| The design must support different consensus algorithms, requiring abstraction over the specific choice of consensus protocol. | ||
| From the project's inception, it was evident that multiple protocols would be required. | ||
| The [Byron era](../references/glossary.md#byron-era) of Cardano utilizes the [PBFT](../references/glossary.md#permissive-bft-pbft) protocol, while the [Shelley era](../references/glossary.md#shelley-based-eras) transitioned to [TPraos](../references/glossary.md#tpraos), and [Praos](../references/glossary.md#ouroboros-praos) has been used since the [Babbage](../references/glossary.md#babbage-era) era. | ||
| The consensus component must support not only the current era but also past eras, requiring the ability to compose protocols. | ||
| Additionally, we must ensure support for integrating new consensus protocols. | ||
|
|
||
| ## Support for Multiple Ledgers | ||
|
|
||
| Similar to the need for multiple consensus protocols, our implementation must support multiple ledger implementations. | ||
| This is crucial for accommodating ledger changes as improvements are made. | ||
| Abstracting over the ledger implementation enables the consensus layer to work with various ledgers. | ||
|
|
||
| ## Decoupling Consensus Protocol from Ledger | ||
|
|
||
| The consensus protocol is designed to be independent of any specific ledger implementation. | ||
| Since multiple ledgers (such as Shelley and its Shelley-based successors) can utilize the same consensus protocol (TPraos or Praos), the consensus protocol is defined based on what it expects or requires from the ledger rather than being tightly coupled to a specific one. | ||
| This approach makes the consensus protocol abstract and reusable across different ledgers. | ||
|
|
||
| ## Testability | ||
|
|
||
| Ensuring the thorough testability of the consensus layer is a critical design goal. | ||
| As a core component of the Cardano Node, which manages the cryptocurrency, the consensus layer must adhere to strict correctness standards. | ||
| Currently, we extensively employ property-based testing. | ||
| Whenever possible, we should abstract over `IO`, enabling simulations of various failures (such as disk or network errors) to verify system recovery capabilities[^1]. | ||
| Additionally, to leverage the property-based methodology, tests must be relatively inexpensive. | ||
| The design should also support testing rare but expected scenarios (such as multiple slot leaders in Praos) by allowing overrides in protocol or ledger behavior at specific points. | ||
| Furthermore, the system should facilitate the isolated testing of individual components. | ||
|
|
||
| ## Adaptability and Maintainability | ||
|
|
||
| The consensus layer was developed as a replacement for a [previous implementation](https://github.com/input-output-hk/cardano-sl), with the immediate goal of transitioning from Byron/BFT to Shelley/Praos while supporting future ledger and protocol changes. | ||
| This called for a flexible and adaptable design. | ||
| Abstracting both the consensus algorithm and the ledger plays a crucial role in achieving this. | ||
| Working with abstract interfaces prevents developers from making assumptions that may hold for one ledger but not others, avoiding costly fixes later. | ||
| This abstraction also allows the consensus layer to be reused in other blockchain projects. | ||
| Most importantly, an abstract design enables extensive testing with simpler mock ledgers, which are easier to set up and reason about compared to the complex real ledger. | ||
| Abstraction is considered good engineering practice, enhancing clarity, reducing dependencies, and making the system easier to understand and maintain. | ||
|
|
||
| ## Composability | ||
|
|
||
| Given the complexity and scale of the consensus layer codebase, it is essential to divide it into smaller, manageable components that can be understood and modified independently. | ||
| Composability is a key technique employed to achieve this. | ||
| A prime example is the [Hard Fork Combinator](../references/glossary.md#hard-fork-combinator) (HFC), which enables the combination of different consensus protocols (such as BFT and Praos) and ledgers (such as Byron and Shelley) into a unified composite protocol or ledger for the hybrid chain. | ||
|
|
||
| ## Predictable Performance | ||
|
|
||
| This goal ensures that node operators can configure nodes for "normal circumstances" without the network failing during infrequent but expected events. | ||
| It aims to make node performance predictable, ensuring that the average-case scenario aligns with the worst-case scenario in terms of resource requirements—not only for security but also to maintain network stability with honest nodes. | ||
|
|
||
| ## Protection Against DoS Attacks | ||
|
|
||
| The consensus layer must help safeguard the network against disruptions, making denial-of-service (DoS) attacks prohibitively expensive for adversaries. | ||
| This involves design decisions that prevent attackers from easily causing a node to perform extensive, wasteful computations. | ||
| For example, validating headers before downloading block bodies prevents attackers from forcing nodes to process potentially invalid blocks. | ||
| The design often seeks a balance between the cost for an attacker to induce work and the cost for a node to defend against it. | ||
|
|
||
| [^1]: See the `IOSim` monad and the `io-classes` package of [`io-sim`](https://input-output-hk.github.io/io-sim/). | ||
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change |
|---|---|---|
| @@ -1 +1,14 @@ | ||
| # Introduction | ||
|
|
||
| Welcome to the documentation for the [`ouroboros-consensus`](https://github.com/IntersectMBO/ouroboros-consensus) repository. | ||
| This repository houses the Haskell implementation of three crucial components utilized by the [`cardano-node`](https://github.com/IntersectMBO/cardano-node): Consensus, Storage, and Mempool. | ||
| - The [Consensus component](https://cardano-scaling.github.io/cardano-blueprint/consensus/index.html) implements the [Ouroboros](https://iohk.io/en/research/library/papers/ouroboros-a-provably-secure-proof-of-stake-blockchain-protocol/) family of Proof-of-Stake protocols. | ||
| - The [Storage component](https://cardano-scaling.github.io/cardano-blueprint/storage/index.html) is responsible for providing efficient access to the blockchain data, as well as maintaining the current and recent past ledger states, and storing ledger state snapshots. | ||
| - The [Mempool component](https://cardano-scaling.github.io/cardano-blueprint/mempool/index.html) serves as a buffer for valid transactions that are waiting to be included in a block. It is used by the Consensus component when forging a block and by the Network layer's transaction submission mini-protocol to diffuse transactions among nodes. | ||
|
|
||
| A core design principle in the implementation of these components is the abstraction from specific ledger and protocol implementations. | ||
| The aim is to decouple the consensus protocol from the ledger and to support multiple consensus algorithms and ledgers for improved adaptability and maintainability. | ||
| This design allows different ledgers (like the Byron or Shelley ledgers) and different Ouroboros protocol instances (like Praos or TPraos) to be integrated into the abstract consensus framework. | ||
| To reflect this design, the repository is structured into different sub-repositories. | ||
| - The polymorphic implementations and abstract classes, which define the core consensus logic independently of specific ledger or protocol details, can be found in the [`ouroboros-consensus`](https://github.com/IntersectMBO/ouroboros-consensus/tree/main/ouroboros-consensus) sub-directory. | ||
| - The Cardano specific instantiations, which provide the concrete implementations, reside in the [`ouroboros-consensus-cardano`](https://github.com/IntersectMBO/ouroboros-consensus/tree/main/ouroboros-consensus-cardano) sub-directory. |
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
should this document have a "see also" section at the bottom with relevant links to the documentation for the various protocols / eras? or have them linked inline?