2021-08-09 16:10:58 +02:00
# Fluffy: The Nimbus Portal Network Client
2021-06-17 17:05:00 +02:00
2023-01-02 16:37:22 +01:00
[![Fluffy CI ](https://github.com/status-im/nimbus-eth1/actions/workflows/fluffy.yml/badge.svg )](https://github.com/status-im/nimbus-eth1/actions/workflows/fluffy.yml)
2021-06-17 17:05:00 +02:00
![Stability: experimental ](https://img.shields.io/badge/stability-experimental-orange.svg )
[![License: Apache ](https://img.shields.io/badge/license-Apache%202.0-blue.svg )](https://opensource.org/licenses/Apache-2.0)
[![License: MIT ](https://img.shields.io/badge/license-MIT-blue.svg )](https://opensource.org/licenses/MIT)
[![Discord: Nimbus ](https://img.shields.io/badge/Discord-Nimbus-blue.svg )](https://discord.gg/XRxWahP)
[![Status: #nimbus-general ](https://img.shields.io/badge/Status-nimbus--general-blue.svg )](https://join.status.im/nimbus-general)
## Introduction
This folder holds the development of the Nimbus client implementation supporting
2023-01-02 16:37:22 +01:00
the Portal Network: Fluffy. The Portal Network is a project still heavily in
2021-08-09 16:10:58 +02:00
research phase and fully in flux. This client is thus still highly experimental.
2021-06-17 17:05:00 +02:00
Current status of specifications can be found in the
2021-09-24 17:18:54 +02:00
[portal-network-specs repository ](https://github.com/ethereum/portal-network-specs/blob/master/portal-network.md ).
2021-06-17 17:05:00 +02:00
## Development Updates
2021-12-13 14:12:51 +01:00
Monthly development updates are shared
[here ](https://hackmd.io/jRpxY4WBQJ-hnsKaPDYqTw ).
2023-01-09 17:57:55 +01:00
To keep up to date with changes and development progress, follow the
[Nimbus blog ](https://our.status.im/tag/nimbus/ ).
2021-06-17 17:05:00 +02:00
## How to Build & Run
### Prerequisites
- GNU Make, Bash and the usual POSIX utilities. Git 2.9.4 or newer.
2023-01-02 16:37:22 +01:00
### Build the Fluffy client
2021-06-17 17:05:00 +02:00
```bash
git clone git@github .com:status-im/nimbus-eth1.git
cd nimbus-eth1
2021-06-28 17:53:13 +02:00
make fluffy
2021-06-17 17:05:00 +02:00
# See available command line options
2021-06-28 17:53:13 +02:00
./build/fluffy --help
2021-06-17 17:05:00 +02:00
2021-12-13 14:12:51 +01:00
# Example command: Run the client and connect to a bootstrap node.
./build/fluffy --bootstrap-node:enr:< base64 encoding of ENR >
2021-06-17 17:05:00 +02:00
```
2023-01-02 16:37:22 +01:00
### Update and rebuild the Fluffy client
2021-06-17 17:05:00 +02:00
```bash
# From the nimbus-eth1 repository
git pull
# To bring the git submodules up to date
make update
2021-06-28 17:53:13 +02:00
make fluffy
2021-06-17 17:05:00 +02:00
```
2023-01-02 16:37:22 +01:00
### Run a Fluffy client on the public testnet
2022-03-17 22:41:43 +01:00
2023-01-02 16:37:22 +01:00
There is a public [Portal testnet ](https://github.com/ethereum/portal-network-specs/blob/master/testnet.md#portal-network-testnet ) which contains nodes of different clients.
We run a fleet of Fluffy nodes that are part of this testnet.
Provide the `--network:testnet0` option to join this network.
2022-03-17 22:41:43 +01:00
```bash
2023-01-02 16:37:22 +01:00
# Connect to the Portal testnet and enable the JSON-RPC APIs
./build/fluffy --network:testnet0 --rpc --table-ip-limit:1024 --bucket-ip-limit:24
2022-03-17 22:41:43 +01:00
```
2023-01-02 16:37:22 +01:00
The `table-ip-limit` and `bucket-ip-limit` options are needed to allow more
nodes with the same IPs in the routing tables. The default limits are there
as security measure. It is currently needed to increase the limits for the testnet
because the fleet of Fluffy nodes runs on only 2 machines / network interfaces.
> **_Note:_** The `--network` option selects automatically a static set of
2022-03-17 22:41:43 +01:00
specific bootstrap nodes belonging to a "testnet". Currently `testnet0` is the
2022-04-13 07:56:01 +02:00
only option, which results in connecting to the
[testnet bootstrap nodes ](https://github.com/ethereum/portal-network-specs/blob/master/testnet.md#bootnodes ).
2023-01-02 16:37:22 +01:00
It should be noted that there is currently no real way to distinguish a "specific" Portal
2022-03-17 22:41:43 +01:00
network, and as long as the same Portal protocols are supported, nodes can
simply connect to it and no real separation can be made.
2023-01-09 17:57:55 +01:00
<!-- TODO: Update this once we have the headersWithProof type merged and data on the network -->
2023-01-02 16:37:22 +01:00
The testnet is currently storing only the first 25000 mainnet blocks. This can
be tested by using the JSON-RPC call `eth_getBlockByHash` :
2022-03-17 22:41:43 +01:00
```
# Get the hash of a block from your favorite block explorer, e.g.:
# 0x8dda3a641653c0454569c3b5be529f58b14d2a5b5d87956664c746ce1e367c21
# Run command to get this block:
curl -s -X POST -H 'Content-Type: application/json' -d '{"jsonrpc":"2.0","id":"1","method":"eth_getBlockByHash","params":["0x8dda3a641653c0454569c3b5be529f58b14d2a5b5d87956664c746ce1e367c21", false]}' http://localhost:8545 | jq
```
2022-04-13 07:56:01 +02:00
One can also use the `blockwalk` tool to walk down the blocks one by one, e.g:
```bash
make fluffy-tools
./build/blockwalk --block-hash:0xf6bfad56d1a45d1661506343dd1e511b5d7e17565b3ec293125ff0890b9709e5
```
2023-01-02 16:37:22 +01:00
### Run Fluffy test suite
2022-04-13 07:56:01 +02:00
```bash
# From the nimbus-eth1 repository
make fluffy-test
```
2022-03-17 22:41:43 +01:00
2023-01-02 16:37:22 +01:00
### Run Fluffy local testnet script
2021-12-13 14:12:51 +01:00
```bash
./fluffy/scripts/launch_local_testnet.sh
```
2022-02-11 14:43:10 +01:00
Find more details on the usage and workings of the local testnet script
[here ](./docs/local_testnet.md ).
2023-01-09 17:57:55 +01:00
### Windows support
2022-06-23 14:14:31 +02:00
2023-01-09 17:57:55 +01:00
Follow the steps outlined [here ](../README.md#windows ) to build fluffy on Windows.
2022-06-23 14:14:31 +02:00
2023-01-09 17:57:55 +01:00
## Development tools and documentation
2022-06-23 14:14:31 +02:00
2023-01-09 17:57:55 +01:00
- [Content seeding ](./docs/content_seeding.md ): Documentation on how to retrieve & generate history data and how to seed it into the network
- [Manual protocol interop testing ](./docs/protocol_interop.md ): commands on how to manually test the discv5 and Portal protocol request and responses
- [Local testnet script ](./docs/local_testnet.md ): Documentation on the local testnet script and how to use it
2022-06-23 14:14:31 +02:00
2023-01-09 17:57:55 +01:00
## The basics for developers
2022-06-23 14:14:31 +02:00
2023-01-09 17:57:55 +01:00
When working on this repository, you can run the `env.sh` script to run a
command with the right environment variables set. This means the vendored
Nim and Nim modules will be used, just as when you use `make` .
E.g.:
2022-06-23 14:14:31 +02:00
2023-01-09 17:57:55 +01:00
```bash
# start a new interactive shell with the right env vars set
./env.sh bash
2022-06-23 14:14:31 +02:00
```
2023-01-09 17:57:55 +01:00
More [development tips ](../README.md#devel-tips )
can be found on the general nimbus-eth1 readme.
The code follows the
[Status Nim Style Guide ](https://status-im.github.io/nim-style-guide/ ).
2021-06-17 17:05:00 +02:00
2022-04-13 16:11:01 +02:00
## Metrics and their visualisation
To enable metrics run Fluffy with the `--metrics` flag:
```bash
./build/fluffy --metrics
```
Default the metrics are available at http://127.0.0.1:8008/metrics.
The address can be changed with the `--metrics-address` and `--metrics-port` options.
This provides only a snapshot of the current metrics. In order track the metrics over
time and to also visualise them one can use for example Prometheus and Grafana.
The steps on how to set up such system is explained in [this guide ](https://nimbus.guide/metrics-pretty-pictures.html#prometheus-and-grafana ).
A Fluffy specific dashboard can be found [here ](./grafana/fluffy_grafana_dashboard.json ).
2021-06-17 17:05:00 +02:00
2022-06-22 17:22:07 +02:00
This is the dashboard used for our Fluffy testnet fleet.
In order to use it locally, you will have to remove the
`{job="nimbus-fluffy-metrics"}` part from the `instance` and `container`
variables queries in the dashboard settings. Or they can also be changed to a
constant value.
The other option would be to remove those variables and remove their usage in
each panel query.
2021-06-17 17:05:00 +02:00
## License
Licensed and distributed under either of
2021-06-28 17:53:13 +02:00
* MIT license: [LICENSE-MIT ](../LICENSE-MIT ) or http://opensource.org/licenses/MIT
2021-06-17 17:05:00 +02:00
or
2021-06-28 17:53:13 +02:00
* Apache License, Version 2.0, ([LICENSE-APACHEv2 ](../LICENSE-APACHEv2 ) or http://www.apache.org/licenses/LICENSE-2.0)
2021-06-17 17:05:00 +02:00
at your option. These files may not be copied, modified, or distributed except according to those terms.