Cosmos Tech
ELI5: Tendermint Consensus
Explore Tendermint Consensus: the core of Cosmos Appchains, offering BFT, low fees, instant finality, and scalability. Learn how it powers diverse applications.
data:image/s3,"s3://crabby-images/bf9f3/bf9f398e5b782d73c11b5f1af4792a8eaa3561e1" alt=""
LeThang
Lead Researcher
Date
April 17, 2023
Explore Tendermint Consensus: the core of Cosmos Appchains, offering BFT, low fees, instant finality, and scalability. Learn how it powers diverse applications.
Every Cosmos Appchains uses Tendermint consensus, which is currently maintained by @informalinc as @CometBFT.
But what makes TendermintBFT special? Here's an ELI5 of Tendermint consensus.
data:image/s3,"s3://crabby-images/52b10/52b105f5a957a96500529b8a70ed673cb71f52be" alt=""
1. The problem
Imagine a blockchain as a database server that only stores a single number. Whenever a user sends a number to it, it will update the value after the majority of the node come to an agreement (Read: Consensus).
In a single-node system, this is easily achieved.
data:image/s3,"s3://crabby-images/0451e/0451e1b16eab724003256c247124fa776e882b94" alt=""
In a decentralized world with multiple validators:
How do they come to consensus?
What happens if one node record a wrong number?
That's the problem Tendermint solved: the Byzantine-Fault Tolerant (BFT) distributed consensus.
data:image/s3,"s3://crabby-images/52b99/52b99565f3e8cdf05a41eb09fef9f5b79502979d" alt=""
2. How Tendermint works
A node can be in 1 of 2 states:
Proposer:
Propose a new block (batch of transactions).
is chosen at the beginning of every epoch based on the stake amount and can't be selected twice in a row.
Validator.
How Tendermint works:
Proposer proposes a block, say a new value = 1.
Validators will send their vote to other nodes (read: Pre-vote).
Once 2/3 of the votes are received by a node, the node will send that result to other nodes (read: Pre-commit).
Nodes wait for pre-commits from 2/3 of all validators to decide whether to update the value to 1 or reject that block.
data:image/s3,"s3://crabby-images/e59cc/e59cce3a37d14fa6c206a9ecc545654928ebad1e" alt=""
As long as > 2/3 of the validators are honest → The system is safe 🛡️
data:image/s3,"s3://crabby-images/0e383/0e3831a0a4b1911b3d131a4d623a9675a2f083d5" alt=""
3. Tendermint features
Low fees
Instant finality
Loose synchrony
Scalability with Appchain Thesis
Blocktimes ~6s. @Injective_ reduce it to 1.1s while @SeiNetwork make it 0.6s
Battle-tested & high TPS (During Terra/UST collapse, it still worked perfectly)
4. Tendermint compatibility
Since Tendermint is a generic consensus protocol, any programming languages and applications (read: state machine) can run on top of Tendermint.
data:image/s3,"s3://crabby-images/d08f6/d08f626d44c789b1adf93475f53002209e1f8ff0" alt=""
5. Who built on top of Tendermint?
Cosmos Appchains: 50+ on mainnet.
Ethereum Dapps: dYdX
Ethereum Layer 2 (Fork of Tendermint): Polygon
Trusted by exchange: OKX chain, Crypto.com chain, Binance Beacon Chain
and more!
6. Modification of Tendermint Consensus
@EvmosOrg built Ethermint = Tendermint + EVM-compatible.
@PolymerDAO is building zkMint, a ZK-friendly Tendermint consensus engine.
@anoma's Typhon consensus solves block proposal bottleneck & increases transactions computation speed by parallelization.
Final words, quoting from the Tendermint Whitepaper
data:image/s3,"s3://crabby-images/c0b7c/c0b7c8b8c41e507f8357d6d1e1155e502894f3f1" alt=""