Skip to content

Commit

Permalink
chore(docs): More info in README (#715)
Browse files Browse the repository at this point in the history
* more context in readmes

* more; main readme

* Cleanup

* moar readmes

* Cleanup

* more specifics in terms of users

* sharpen language

* flexible

* Apply suggestions from code review

Co-authored-by: Bastien Faivre <[email protected]>

* fixes after Bastien's review

---------

Co-authored-by: Romain Ruetschi <[email protected]>
Co-authored-by: Bastien Faivre <[email protected]>
  • Loading branch information
3 people authored Dec 19, 2024
1 parent da906e1 commit 1f16e9f
Show file tree
Hide file tree
Showing 6 changed files with 75 additions and 18 deletions.
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/).
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.

## 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

0 comments on commit 1f16e9f

Please sign in to comment.