2020-05-26 08:30:44 +00:00
# Simple Local Testnet
2021-03-30 05:17:58 +00:00
These scripts allow for running a small local testnet with multiple beacon nodes and validator clients.
This setup can be useful for testing and development.
2020-05-26 08:30:44 +00:00
## Requirements
2021-03-30 05:17:58 +00:00
The scripts require `lcli` and `lighthouse` to be installed on `PATH` . From the
2020-05-26 08:30:44 +00:00
root of this repository, run:
```bash
2021-03-30 05:17:58 +00:00
make
make install-lcli
2020-05-26 08:30:44 +00:00
```
## Starting the testnet
2021-10-01 06:32:37 +00:00
Modify `vars.env` as desired.
Start a local eth1 ganache server plus boot node along with `BN_COUNT`
number of beacon nodes and `VC_COUNT` validator clients.
2023-03-30 10:14:07 +00:00
The `start_local_testnet.sh` script takes four options `-v VC_COUNT` , `-d DEBUG_LEVEL` , `-p` to enable builder proposals and `-h` for help.
2021-10-01 06:32:37 +00:00
The options may be in any order or absent in which case they take the default value specified.
- VC_COUNT: the number of validator clients to create, default: `BN_COUNT`
- DEBUG_LEVEL: one of { error, warn, info, debug, trace }, default: `info`
```bash
./start_local_testnet.sh
```
## Stopping the testnet
This is not necessary before `start_local_testnet.sh` as it invokes `stop_local_testnet.sh` automatically.
```bash
./stop_local_testnet.sh
```
## Manual creation of local testnet
These scripts are used by ./start_local_testnet.sh and may be used to manually
2021-03-30 05:17:58 +00:00
Start a local eth1 ganache server
```bash
./ganache_test_node.sh
```
2021-09-07 03:14:03 +00:00
Assuming you are happy with the configuration in `vars.env` , deploy the deposit contract, make deposits,
2021-03-30 05:17:58 +00:00
create the testnet directory, genesis state and validator keys with:
2020-05-26 08:30:44 +00:00
```bash
2020-08-11 02:16:33 +00:00
./setup.sh
2020-05-26 08:30:44 +00:00
```
2021-03-30 05:17:58 +00:00
Generate bootnode enr and start a discv5 bootnode so that multiple beacon nodes can find each other
```bash
./bootnode.sh
```
Start a beacon node:
2020-05-26 08:30:44 +00:00
```bash
2021-03-30 05:17:58 +00:00
./beacon_node.sh < DATADIR > < NETWORK-PORT > < HTTP-PORT > < OPTIONAL-DEBUG-LEVEL >
```
e.g.
```bash
./beacon_node.sh $HOME/.lighthouse/local-testnet/node_1 9000 8000
2020-05-26 08:30:44 +00:00
```
In a new terminal, start the validator client which will attach to the first
beacon node:
```bash
2021-03-30 05:17:58 +00:00
./validator_client.sh < DATADIR > < BEACON-NODE-HTTP > < OPTIONAL-DEBUG-LEVEL >
2020-05-26 08:30:44 +00:00
```
2021-03-30 05:17:58 +00:00
e.g. to attach to the above created beacon node
2020-05-26 08:30:44 +00:00
```bash
2021-03-30 05:17:58 +00:00
./validator_client.sh $HOME/.lighthouse/local-testnet/node_1 http://localhost:8000
2020-05-26 08:30:44 +00:00
```
2021-03-30 05:17:58 +00:00
You can create additional beacon node and validator client instances with appropriate parameters.
2020-05-26 08:30:44 +00:00
2021-03-30 05:17:58 +00:00
## Additional Info
2020-05-26 08:30:44 +00:00
2021-03-30 05:17:58 +00:00
### Adjusting number and distribution of validators
The `VALIDATOR_COUNT` parameter is used to specify the number of insecure validator keystores to generate and make deposits for.
2021-10-01 06:32:37 +00:00
The `BN_COUNT` parameter is used to adjust the division of these generated keys among separate validator client instances.
For e.g. for `VALIDATOR_COUNT=80` and `BN_COUNT=4` , the validator keys are distributed over 4 datadirs with 20 keystores per datadir. The datadirs are located in `$DATADIR/node_{i}` which can be passed to separate validator client
2021-03-30 05:17:58 +00:00
instances using the `--datadir` parameter.
2020-05-26 08:30:44 +00:00
### Starting fresh
2021-10-01 06:32:37 +00:00
Delete the current testnet and all related files using. Generally not necessary as `start_local_test.sh` does this each time it starts.
2020-05-26 08:30:44 +00:00
```bash
2020-08-11 02:16:33 +00:00
./clean.sh
2020-05-26 08:30:44 +00:00
```
### Updating the genesis time of the beacon state
If it's been a while since you ran `./setup` then the genesis time of the
genesis state will be far in the future, causing lots of skip slots.
Update the genesis time to now using:
```bash
2020-08-11 02:16:33 +00:00
./reset_genesis_time.sh
2020-05-26 08:30:44 +00:00
```
2021-10-01 06:32:37 +00:00
> Note: you probably want to just rerun `./start_local_testnet.sh` to start over
> but this is another option.