Ream
What is Ream
Ream aims to be modular, contributor-friendly, and blazingly fast implementation of the Beam Chain specification. One of our goals is to build an ecosystem where developers can seamlessly build on Ream, saving time and avoiding the need to reinvent the wheel.
Join
Build from Source
You can build Ream on Linux.
Dependencies
First install Rust using rustup:
curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh
There are some other dependencies you need to install based on your operating system (OS):
- Ubuntu/Debian:
apt-get install libclang-dev pkg-config libssl-dev build-essential
Install cargo-sort and cargo-udeps tools.
cargo install cargo-sort cargo-udeps
Build Ream
Clone the repository and move to the directory:
git clone git@github.com:reamlabs/ream.git
cd ream
After everything is setup, you can start the build:
make build
CLI Reference
The Ream node is operated via the CLI by running the ream node
command. To stop it, press ctrl-c
. You may need to wait a bit as Ream tears down existing p2p connections or other cleanup tasks.
However, Ream has more commands:
ream
A Rust implementation of the Ethereum Beam Chain specification.
$ ream --help
Usage: ream <COMMAND>
Commands:
node Start the node
help Print this message or the help of the given subcommand(s)
Options:
-h, --help Print help
-V, --version Print version
ream node
Start the node
$ ream node --help
Usage: ream node [OPTIONS]
Options:
-v, --verbosity <VERBOSITY>
Verbosity level [default: 3]
--network <NETWORK>
Choose mainnet, holesky, sepolia, hoodi or dev [default: mainnet]
--http-address <HTTP_ADDRESS>
Set HTTP address [default: 127.0.0.1]
--http-port <HTTP_PORT>
Set HTTP Port [default: 5052]
--http-allow-origin
--socket-address <SOCKET_ADDRESS>
Set P2P socket address [default: 0.0.0.0]
--socket-port <SOCKET_PORT>
Set P2P socket port (TCP) [default: 9000]
--discovery-port <DISCOVERY_PORT>
Discovery 5 listening port (UDP) [default: 9000]
--disable-discovery
Disable Discv5
--data-dir <DATA_DIR>
The directory for storing application data. If used together with --ephemeral, new child directory will be created.
-e, --ephemeral
Use new data directory, located in OS temporary directory. If used together with --data-dir, new directory will be created there instead.
--bootnodes <BOOTNODES>
One or more comma-delimited base64-encoded ENR's of peers to initially connect to. Use 'default' to use the default bootnodes for the network. Use 'none' to disable bootnodes. [default: default]
-h, --help
Print help
Changelog
To view all Changes made to the project, run this in your terminal:
git log --pretty="-%s"
To add all Changes in a Changelog.md
file, run this in your terminal:
git log --pretty="- %s" > CHANGELOG.md