mirror of
https://gitlab.com/pulsechaincom/lighthouse-pulse.git
synced 2025-01-03 17:54:28 +00:00
Add missed book pages
This commit is contained in:
parent
aa3bc6bf67
commit
8b4b13cb2f
104
book/src/interop-tips.md
Normal file
104
book/src/interop-tips.md
Normal file
@ -0,0 +1,104 @@
|
|||||||
|
# Interop Tips & Tricks
|
||||||
|
|
||||||
|
This document contains a list of tips and tricks that may be useful during
|
||||||
|
interop testing.
|
||||||
|
|
||||||
|
## Command-line Interface
|
||||||
|
|
||||||
|
The `--help` command provides detail on the CLI interface. Here are some
|
||||||
|
interop-specific CLI commands.
|
||||||
|
|
||||||
|
### Specify a boot node by multiaddr
|
||||||
|
|
||||||
|
You can specify a static list of multiaddrs when booting Lighthouse using
|
||||||
|
the `--libp2p-addresses` command.
|
||||||
|
|
||||||
|
#### Example:
|
||||||
|
|
||||||
|
Runs an 8 validator quick-start chain, peering with `/ip4/192.168.0.1/tcp/9000` on boot.
|
||||||
|
|
||||||
|
```
|
||||||
|
$ ./beacon_node --libp2p-addresses /ip4/192.168.0.1/tcp/9000 testnet -f quick 8 1567222226
|
||||||
|
```
|
||||||
|
|
||||||
|
### Specify a boot node by ENR
|
||||||
|
|
||||||
|
You can specify a static list of Discv5 addresses when booting Lighthouse using
|
||||||
|
the `--boot-nodes` command.
|
||||||
|
|
||||||
|
#### Example:
|
||||||
|
|
||||||
|
Runs an 8 validator quick-start chain, peering with `-IW4QB2...` on boot.
|
||||||
|
|
||||||
|
```
|
||||||
|
$ ./beacon_node --boot-nodes -IW4QB2Hi8TPuEzQ41Cdf1r2AUU1FFVFDBJdJyOkWk2qXpZfFZQy2YnJIyoT_5fnbtrXUouoskmydZl4pIg90clIkYUDgmlwhH8AAAGDdGNwgiMog3VkcIIjKIlzZWNwMjU2azGhAjg0-DsTkQynhJCRnLLttBK1RS78lmUkLa-wgzAi-Ob5 testnet -f quick 8 1567222226
|
||||||
|
```
|
||||||
|
|
||||||
|
### Avoid port clashes when starting nodes
|
||||||
|
|
||||||
|
Starting a second Lighthouse node on the same machine will fail due to TCP/UDP
|
||||||
|
port collisions. Use the `-b` (`--port-bump`) flag to increase all listening
|
||||||
|
ports by some `n`.
|
||||||
|
|
||||||
|
#### Example:
|
||||||
|
|
||||||
|
Increase all ports by `10` (using multiples of `10` is recommended).
|
||||||
|
|
||||||
|
```
|
||||||
|
$ ./beacon_node -b 10 testnet -f quick 8 1567222226
|
||||||
|
```
|
||||||
|
|
||||||
|
## HTTP API
|
||||||
|
|
||||||
|
Examples assume there is a Lighthouse node exposing a HTTP API on
|
||||||
|
`localhost:5052`. Responses are JSON.
|
||||||
|
|
||||||
|
### Get the node's ENR
|
||||||
|
|
||||||
|
```
|
||||||
|
$ curl localhost:5052/network/enr
|
||||||
|
|
||||||
|
"-IW4QFyf1VlY5pZs0xZuvKMRZ9_cdl9WMCDAAJXZiZiuGcfRYoU40VPrYDLQj5prneJIz3zcbTjHp9BbThc-yiymJO8HgmlwhH8AAAGDdGNwgiMog3VkcIIjKIlzZWNwMjU2azGhAjg0-DsTkQynhJCRnLLttBK1RS78lmUkLa-wgzAi-Ob5"%
|
||||||
|
```
|
||||||
|
|
||||||
|
### Get a list of connected peer ids
|
||||||
|
|
||||||
|
```
|
||||||
|
$ curl localhost:5052/network/peers
|
||||||
|
|
||||||
|
["QmeMFRTWfo3KbVG7dEBXGhyRMa29yfmnJBXW84rKuGEhuL"]%
|
||||||
|
```
|
||||||
|
|
||||||
|
### Get the node's peer id
|
||||||
|
|
||||||
|
```
|
||||||
|
curl localhost:5052/network/peer_id
|
||||||
|
|
||||||
|
"QmRD1qs2AqNNRdBcGHUGpUGkpih5cmdL32mhh22Sy79xsJ"%
|
||||||
|
```
|
||||||
|
|
||||||
|
### Get the list of listening libp2p addresses
|
||||||
|
|
||||||
|
Lists all the libp2p multiaddrs that the node is listening on.
|
||||||
|
|
||||||
|
```
|
||||||
|
curl localhost:5052/network/listen_addresses
|
||||||
|
|
||||||
|
["/ip4/127.0.0.1/tcp/9000","/ip4/192.168.1.121/tcp/9000","/ip4/172.17.0.1/tcp/9000","/ip4/172.42.0.1/tcp/9000","/ip6/::1/tcp/9000","/ip6/fdd3:c293:1bc::203/tcp/9000","/ip6/fdd3:c293:1bc:0:9aa9:b2ea:c610:44db/tcp/9000"]%
|
||||||
|
```
|
||||||
|
|
||||||
|
### Get the node's beacon chain head
|
||||||
|
|
||||||
|
```
|
||||||
|
curl localhost:5052/beacon/head
|
||||||
|
|
||||||
|
{"slot":0,"block_root":"0x827bf71805540aa13f6d8c7d18b41b287b2094a4d7a28cbb8deb061dbf5df4f5","state_root":"0x90a78d73294bc9c7519a64e1912161be0e823eb472012ff54204e15a4d717fa5"}%
|
||||||
|
```
|
||||||
|
|
||||||
|
### Get the node's finalized checkpoint
|
||||||
|
|
||||||
|
```
|
||||||
|
curl localhost:5052/beacon/latest_finalized_checkpoint
|
||||||
|
|
||||||
|
{"epoch":0,"root":"0x0000000000000000000000000000000000000000000000000000000000000000"}%
|
||||||
|
```
|
80
book/src/simple-testnet.md
Normal file
80
book/src/simple-testnet.md
Normal file
@ -0,0 +1,80 @@
|
|||||||
|
# Simple Local Testnet
|
||||||
|
|
||||||
|
You can setup a local, two-node testnet in **Only Three CLI Commands™**.
|
||||||
|
|
||||||
|
Follow the [Quick instructions](#tldr) version if you're confident, or see
|
||||||
|
[Detailed instructions](#detail) for more.
|
||||||
|
|
||||||
|
|
||||||
|
## Quick instructions
|
||||||
|
|
||||||
|
Setup a development environment, build the project and navigate to the
|
||||||
|
`target/release` directory.
|
||||||
|
|
||||||
|
1. Start the first node: `$ ./beacon_node testnet -f recent 8`
|
||||||
|
1. Start a validator client: `$ ./validator_client testnet -b insecure 0 8`
|
||||||
|
1. Start another node `$ ./beacon_node -b 10 testnet -f bootstrap http://localhost:5052`
|
||||||
|
|
||||||
|
_Repeat #3 to add more nodes._
|
||||||
|
|
||||||
|
## Detailed instructions
|
||||||
|
|
||||||
|
First, setup a Lighthouse development environment and navigate to the
|
||||||
|
`target/release` directory (this is where the binaries are located).
|
||||||
|
|
||||||
|
## Starting the Beacon Node
|
||||||
|
|
||||||
|
Start a new node (creating a fresh database and configuration in `~/.lighthouse`), using:
|
||||||
|
|
||||||
|
```
|
||||||
|
$ ./beacon_node testnet -f recent 8
|
||||||
|
```
|
||||||
|
|
||||||
|
> Notes:
|
||||||
|
>
|
||||||
|
> - The `-f` flag ignores any existing database or configuration, backing them
|
||||||
|
> up before re-initializing.
|
||||||
|
> - `8` is number of validators with deposits in the genesis state.
|
||||||
|
> - See `$ ./beacon_node testnet recent --help` for more configuration options,
|
||||||
|
> including `minimal`/`mainnet` specification.
|
||||||
|
|
||||||
|
## Starting the Validator Client
|
||||||
|
|
||||||
|
In a new terminal window, start the validator client with:
|
||||||
|
|
||||||
|
```
|
||||||
|
$ ./validator_client testnet -b insecure 0 8
|
||||||
|
```
|
||||||
|
|
||||||
|
> Notes:
|
||||||
|
>
|
||||||
|
> - The `-b` flag means the validator client will "bootstrap" specs and config
|
||||||
|
> from the beacon node.
|
||||||
|
> - The `insecure` command uses predictable, well-known private keys. Since
|
||||||
|
> this is just a local testnet, these are fine.
|
||||||
|
> - The `0 8` indicates that this validator client should manage 8 validators,
|
||||||
|
> starting at validator 0 (the first deposited validator).
|
||||||
|
> - The validator client will try to connect to the beacon node at `localhost`.
|
||||||
|
> See `--help` to configure that address and other features.
|
||||||
|
|
||||||
|
## Adding another Beacon Node
|
||||||
|
|
||||||
|
You may connect another (non-validating) node to your local network using the
|
||||||
|
lighthouse `bootstrap` command.
|
||||||
|
|
||||||
|
In a new terminal terminal, run:
|
||||||
|
|
||||||
|
|
||||||
|
```
|
||||||
|
$ ./beacon_node -b 10 testnet -r bootstrap http://localhost:5052
|
||||||
|
```
|
||||||
|
|
||||||
|
> Notes:
|
||||||
|
>
|
||||||
|
> - The `-b` (or `--port-bump`) increases all the listening TCP/UDP ports of
|
||||||
|
> the new node to `10` higher. Your first node's HTTP server was at TCP
|
||||||
|
> `5052` but this one will be at `5062`.
|
||||||
|
> - The `-r` flag creates a new data directory in your home with a random
|
||||||
|
> string appended, to avoid conflicting with any other running node.
|
||||||
|
> - The HTTP address is the API of the first node. The new node will download
|
||||||
|
> configuration via HTTP before starting sync via libp2p.
|
Loading…
Reference in New Issue
Block a user