Skip to content
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

chore(docs): More info in README #715

Merged
merged 10 commits into from
Dec 19, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
40 changes: 32 additions & 8 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -23,18 +23,40 @@

## About

Malachite is a Byzantine-fault tolerant (BFT) consensus library implemented in Rust.
The goal is to enable developers to decentralize whatever the future may bring—sequencers, social networks, Layer 1s, etc.

Bundled with Malachite comes a state-of-the-art implementation of the Tendermint consensus algorithm.
Tendermint is a BFT consensus algorithm that is [optimistically responsive][responsive] and therefore exhibits high-performance.
Additionally, this algorithm found adoption in many decentralized systems through its implementation in Go as part of [CometBFT](https://github.com/cometbft/cometbft/).
CometBFT has been battle-tested for years, and many of the lessons and experiences of maintaining CometBFT inspired key [design decisions][announcement] that we took in Malachite.
Malachite is a Byzantine-fault tolerant (BFT) consensus engine implemented in Rust.

> [!IMPORTANT]
> Malachite is pre-alpha software and still under heavy development.
> At this stage, it is not meant for use in production.
> The software is provided "as is" and has not been externally audited, use at your own risk.
> The software is provided "as is" and has not been externally audited; use at your own risk.

### Goals

The goal is for Malachite to enable developers to decentralize whatever the future may bring—sequencers, social networks, Layer 1s, etc.
Therefore, Malachite addresses a particular void in the market: The lack of flexible, reliable, and high-performance distributed systems foundations, such as BFT consensus libraries.

### Features

#### Tendermint as a Library
Bundled with Malachite comes a state-of-the-art implementation of the Tendermint BFT consensus algorithm.
Tendermint is an [optimistically responsive][responsive] consensus algorithm, and therefore exhibits high-performance, and has found adoption in many decentralized systems through its implementation in Go as part of [CometBFT](https://github.com/cometbft/cometbft/).

#### Design
Key [design decisions][announcement] in Malachite are heavily inspired by lessons and experiences of maintaining CometBFT throughout the years.
Malachite addresses numerous points of technical debt in the design of consensus engines, resulting in a lean, flexible, and reliable solution that performs at the highest level.

#### Reliability and Performance
Parts of Malachite were co-designed with their formal specification and model checking, notably for the Tendermint algorithm, which improved the confidence and reliability of this core library.

Early [experiments][announcement] with Malachite show an average finalization latency of 780 ms at a scale of 100 validators with 1MB blocks.
Depending on the setup, Malachite can clear up to 2.5 blocks per second or finalize up to 13.5 MB/s (around 50,000 transactions per second).

#### Use-cases
Malachite originated as a consensus core for the Starknet L2 decentralized sequencer.
It will serve as the core consensus library in the [Madara][madara] and [Pathfinder][pathfinder] Starknet clients.
Malachite is also being used for Farcaster’s newest backend layer called [Snapchain](https://github.com/farcasterxyz/snapchain-v0/).
adizere marked this conversation as resolved.
Show resolved Hide resolved
Thanks to its flexible design, Malachite is amenable to a broad range of environments, and a number of other teams are building and exploring in private.
Please reach-out if interested, we would love to speak with more teams.
adizere marked this conversation as resolved.
Show resolved Hide resolved

## Overview

Expand Down Expand Up @@ -134,6 +156,8 @@ Unless required by applicable law or agreed to in writing, software distributed
[tg-badge]: https://img.shields.io/badge/Malachite-Engine-blue.svg?logo=
[responsive]: https://informal.systems/blog/tendermint-responsiveness
[announcement]: https://informal.systems/blog/malachite-decentralize-whatever
[madara]: https://github.com/madara-alliance/madara
[pathfinder]: https://github.com/eqlabs/pathfinder

[//]: # (crates.io and docs.rs: links and badges)
[core-consensus-crate-image]: https://img.shields.io/crates/v/informalsystems-malachitebft-core-consensus
Expand Down
24 changes: 24 additions & 0 deletions docs/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,24 @@
# Malachite Docs

> [!TIP]
> Malachite documentation is still in the early stages of development.
> We welcome contributions!
> We also invite feedback and input on what would be the most important aspects
> of documentation to cover, for [example](https://diataxis.fr/), tutorials,
> how-to guides, explanations, references?

## Building with Malachite

If you are a developer looking to _build_ with Malachite, then we suggest as a starting point:

1. The main [ARCHITECTURE.MD](../ARCHITECTURE.md)
2. The [tutorials](tutorials), which currently comprises an example of how to build a simple application with the high-level interface to a consensus provided by Malachite.

## Contributing to Malachite

If you are a developer looking to _contribute_ to Malachite or learn more,
then, in addition to the resources above, you may want to consult:

1. The log of Architecture Decision Records (ADRs) in [architecture](./architecture); these capture various decisions at previous points in time regarding architectural concerns.
2. The log of [development proposals](./development-proposals), which describes potential improvements or features for Malachite, depending on specific use cases such as the Starknet decentralized sequencer.
3. Some notes on [testing](./testing) Malachite locally within Docker.
6 changes: 6 additions & 0 deletions docs/testing/README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
# Malachite Testing Notes

This directory collects notes on testing and experimenting with Malachite.
Please see [QA](../../qa) for more comprehensive testing.

- [Testing Malachite locally with Docker](./local.md)
7 changes: 5 additions & 2 deletions specs/README.md
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
# Malachite's Specification
# Malachite Specifications

Malachite is an implementation of the [Tendermint consensus algorithm][tendermint-arxiv] in Rust.
This directory holds specifications of various Malachite components or protocols.
It also covers specifications related to external dependencies, i.e., application-level concerns.
For example, Malachite comprises a library implementing the [Tendermint consensus algorithm][tendermint-arxiv] in Rust, which is specified below.
The specifications also cover networking, synchronization, and broader Starknet protocols.

- [Consensus algorithm and implementation](./consensus/README.md)
- [Network design and requirements](./network/README.md)
Expand Down
8 changes: 4 additions & 4 deletions specs/consensus/README.md
Original file line number Diff line number Diff line change
@@ -1,14 +1,14 @@
# Malachite Consensus

Malachite is an implementation of the [Tendermint consensus algorithm][tendermint-arxiv] in Rust.
It comes together with an executable specification in [Quint][quint-spec].
Malachite `core` libraries implement the [Tendermint consensus algorithm][tendermint-arxiv] in Rust.
These libraries come together with an executable specification in [Quint][quint-spec].
We use model-based testing to make sure that the implementation corresponds to
the specification.

The specification of the consensus algorithm and its implementation is organized as follows:
The specification of the consensus algorithm covers several concerns and is organized as follows:

- [**overview.md**](./overview.md): a summary of the operation and components
of the Tendermint consensus algorithm;
of the Tendermint consensus algorithm at the protocol level;
- [**pseudo-code.md**](./pseudo-code.md): the Algorithm in page 6 of the
Tendermint [paper][tendermint-pdf];
since it is referenced several times in this specification, for simplicity and
Expand Down
8 changes: 4 additions & 4 deletions specs/starknet/README.md
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
# Starknet

Malachite was originally designed to be the consensus engine for the
[Starknet network][starknet].
Malachite originates as the consensus engine for implementing the decentralized sequencer of
[Starknet L2 network][starknet].

This directory contains the specification of Starknet components contemplates
by the Malachite's design:
This directory contains the specification of various Starknet protocols, as they
interact and depend on Malachite's design:

- [Proofs Scheduling Protocol](./proofs-scheduling/README.md)
- [Forced Staking Updates and Reset Protocol](./validator-updates/README.md)
Expand Down
Loading