mirror of
https://github.com/hl-archive-node/nanoreth.git
synced 2025-12-06 10:59:55 +00:00
179 lines
7.9 KiB
Markdown
179 lines
7.9 KiB
Markdown
## Project Layout
|
|
|
|
This repository contains several Rust crates that implement the different building blocks of an Ethereum node. The high-level structure of the repository is as follows:
|
|
|
|
Generally reth is composed of a few components, with supporting crates. The main components can be defined as:
|
|
|
|
- [Project Layout](#project-layout)
|
|
- [Documentation](#documentation)
|
|
- [Binaries](#binaries)
|
|
- [Storage](#storage)
|
|
- [Networking](#networking)
|
|
- [Common](#common)
|
|
- [Discovery](#discovery)
|
|
- [Protocol](#protocol)
|
|
- [Downloaders](#downloaders)
|
|
- [Consensus](#consensus)
|
|
- [Execution](#execution)
|
|
- [Sync](#sync)
|
|
- [RPC](#rpc)
|
|
- [Transports](#transports)
|
|
- [Common](#common-1)
|
|
- [Utilities Crates](#utilities-crates)
|
|
- [Payloads](#payloads)
|
|
- [Primitives](#primitives)
|
|
- [Optimism](#optimism)
|
|
- [Misc](#misc)
|
|
|
|
The supporting crates are split into two categories: [primitives](#primitives) and [miscellaneous](#misc).
|
|
|
|
### Documentation
|
|
|
|
Contributor documentation is in [`docs`](../../docs) and end-user documentation is in [`book`](../../book).
|
|
|
|
### Binaries
|
|
|
|
All binaries are stored in [`bin`](../../bin).
|
|
|
|
### Storage
|
|
|
|
These crates are related to the database.
|
|
|
|
- [`storage/codecs`](../../crates/storage/codecs): Different storage codecs.
|
|
- [`storage/libmdbx-rs`](../../crates/storage/libmdbx-rs): Rust bindings for [libmdbx](https://libmdbx.dqdkfa.ru). A fork of an earlier Apache-licensed version of [libmdbx-rs][libmdbx-rs].
|
|
- [`storage/db`](../../crates/storage/db): Strongly typed Database abstractions (transactions, cursors, tables) over lower level database backends.
|
|
- Implemented backends: mdbx
|
|
- [`storage/provider`](../../crates/storage/provider): Traits which provide a higher level api over the database to access the Ethereum state and historical data (transactions, blocks etc.)
|
|
|
|
|
|
### Networking
|
|
|
|
These crates are related to networking (P2P).
|
|
|
|
The networking component mainly lives in [`net/network`](../../crates/net/network), which handles:
|
|
|
|
- Message egress/ingress
|
|
- Peer management
|
|
- Session management
|
|
|
|
#### Common
|
|
|
|
- [`net/banlist`](../../crates/net/banlist): A simple peer banlist that can be used to ban peers or IP addresses.
|
|
- Contains: Peer banlist.
|
|
- [`net/network-api`](../../crates/net/network-api): Contains traits that define the networking component as a whole. Other components that interface with the network stack only need to depend on this crate for the relevant types.
|
|
- [`net/nat`](../../crates/net/nat): A small helper crate that resolves the external IP of the running node using various methods (such as a manually provided IP, using UPnP etc.)
|
|
|
|
#### Discovery
|
|
|
|
- [`net/discv4`](../../crates/net/discv4): An implementation of the [discv4][discv4] protocol
|
|
- [`net/dns`](../../crates/net/dns): An implementation of node discovery via DNS ([EIP-1459][eip-1459])
|
|
|
|
#### Protocol
|
|
|
|
- [`net/eth-wire`](../../crates/net/eth-wire): Implements the `eth` wire protocol and the ``RLPx`` networking stack.
|
|
- [`net/ecies`](../../crates/net/ecies): Implementation of the Elliptic Curve Integrated Encryption Scheme used in the ``RLPx`` handshake.
|
|
|
|
#### Downloaders
|
|
|
|
- [`net/downloaders`](../../crates/net/downloaders): Traits defining block body and header downloaders, as well as P2P implementations of both.
|
|
|
|
### Consensus
|
|
|
|
Different consensus mechanisms.
|
|
|
|
- [`consensus/common`](../../crates/consensus/common): Common consensus functions and traits (e.g. fee calculation)
|
|
- [`consensus/beacon`](../../crates/consensus/beacon): Consensus mechanism that handles messages from a beacon node ("eth2")
|
|
|
|
### Execution
|
|
|
|
Crates related to transaction execution.
|
|
|
|
- [`revm`](../../crates/revm): Revm utils and implementations specific to reth.
|
|
- [`evm`](../../crates/evm): Traits for configuring an EVM specifics.
|
|
- [`execution-types`](../../crates/evm/execution-types): Commonly used types for (EVM) block execution.
|
|
- [`execution-errors`](../../crates/evm/execution-errors): Commonly used error types used when doing block execution.
|
|
|
|
### Sync
|
|
|
|
These crates implement the main syncing drivers of reth.
|
|
|
|
- [`blockchain-tree`](../../crates/blockchain-tree): A tree-like structure for handling multiple chains of unfinalized blocks. This is the main component during live sync (i.e. syncing at the tip)
|
|
- [`stages`](../../crates/stages): A pipelined sync, including implementation of various stages. This is used during initial sync and is faster than the tree-like structure for longer sync ranges.
|
|
|
|
### RPC
|
|
|
|
Crates related to the RPC component (including IPC transport)
|
|
|
|
The RPC component mainly lives in [`rpc/rpc`](../../crates/rpc/rpc), which implements the following namespaces:
|
|
|
|
- `admin_`
|
|
- `debug_` (includes Geth-style tracing APIs)
|
|
- `eth_`
|
|
- `net_`
|
|
- `trace_` (OpenEthereum-style tracing APIs)
|
|
- `txpool_`
|
|
- `web3_`
|
|
|
|
These RPC interface is defined in [`rpc/rpc-api`](../../crates/rpc/rpc-api).
|
|
|
|
The engine API ([`engine_`][engine-spec]) lives in [`rpc/rpc-engine-api`](../../crates/rpc/rpc-engine-api) (this is *not* an interface crate despite the confusing name).
|
|
|
|
There is also a crate to easily configure an RPC server: [`rpc/rpc-builder`](../../crates/rpc/rpc-builder).
|
|
|
|
#### Transports
|
|
|
|
The RPC component is based on the [`jsonrpsee`][jsonrpsee] crate which provides JSONRPC over WebSockets and HTTP.
|
|
|
|
The IPC transport lives in [`rpc/ipc`](../../crates/rpc/ipc).
|
|
|
|
#### Common
|
|
|
|
- [`rpc/rpc-api`](../../crates/rpc/rpc-api): RPC traits
|
|
- Supported transports: HTTP, WS, IPC
|
|
- Supported namespaces: `eth_`, `engine_`, `debug_`
|
|
- [`rpc/rpc-eth-api`](../../crates/rpc/rpc-eth-api/): Reth RPC 'eth' namespace API (including interface and implementation), this crate is re-exported by `rpc/rpc-api`
|
|
- [`rpc/rpc-eth-types`](../../crates/rpc/rpc-eth-types/): Types `supporting the implementation` of 'eth' namespace RPC server API
|
|
- [`rpc/rpc-server-types`](../../crates/rpc/rpc-server-types/): RPC server types and constants
|
|
|
|
#### Utilities Crates
|
|
|
|
- [`rpc/rpc-types-compat`](../../crates/rpc/rpc-types-compat): This crate various helper functions to convert between reth primitive types and rpc types.
|
|
- [`rpc/layer`](../../crates/rpc/rpc-layer/): Some RPC middleware layers (e.g. `AuthValidator`, `JwtAuthValidator`)
|
|
- [`rpc/rpc-testing-util`](../../crates/rpc/rpc-testing-util/): Reth RPC testing helpers
|
|
|
|
### Payloads
|
|
|
|
Crates related to building and validating payloads (blocks).
|
|
|
|
- [`transaction-pool`](../../crates/transaction-pool): An in-memory pending transactions pool.
|
|
- [`payload/builder`](../../crates/payload/builder): Abstractions for payload building and a payload builder service that works with multiple kinds of payload resolvers.
|
|
- [`payload/basic`](../../crates/payload/basic): A basic payload generator.
|
|
|
|
### Primitives
|
|
|
|
These crates define primitive types or algorithms.
|
|
|
|
- [`primitives`](../../crates/primitives): Commonly used types in Reth.
|
|
- [`primitives-traits`](../../crates/primitives-traits/): Common abstracted types in reth.
|
|
- [`trie`](../../crates/trie): An implementation of a Merkle Patricia Trie used for various roots (e.g. the state root) in Ethereum.
|
|
|
|
### Optimism
|
|
|
|
Crates related to the Optimism rollup live in [optimism](../../crates/optimism/).
|
|
|
|
### Misc
|
|
|
|
Small utility crates.
|
|
|
|
- [`tasks`](../../crates/tasks): An executor-agnostic task abstraction, used to spawn tasks on different async executors. Supports blocking tasks and handles panics gracefully. A tokio implementation is provided by default.
|
|
- [`metrics/common`](../../crates/metrics/src/common): Common metrics types (e.g. metered channels)
|
|
- [`metrics/metrics-derive`](https://github.com/rkrasiuk/metrics-derive): A derive-style API for creating metrics
|
|
- [`tracing`](../../crates/tracing): A small utility crate to install a uniform [`tracing`][tracing] subscriber
|
|
|
|
[libmdbx-rs]: https://crates.io/crates/libmdbx
|
|
[discv4]: https://github.com/ethereum/devp2p/blob/master/discv4.md
|
|
[jsonrpsee]: https://github.com/paritytech/jsonrpsee/
|
|
[tracing]: https://crates.io/crates/tracing
|
|
[eip-1459]: https://eips.ethereum.org/EIPS/eip-1459
|
|
[engine-spec]: https://github.com/ethereum/execution-apis/tree/main/src/engine
|