forked from TrueCloudLab/neoneo-go
Merge pull request #2068 from nspcc-dev/cn-instr
docs: add more info about running a CN node on public networks
This commit is contained in:
commit
d45b1b356c
2 changed files with 125 additions and 3 deletions
|
@ -83,6 +83,9 @@ Available network flags:
|
||||||
- `--privnet, -p`
|
- `--privnet, -p`
|
||||||
- `--testnet, -t`
|
- `--testnet, -t`
|
||||||
|
|
||||||
|
To run a consensus/committee node refer to [consensus
|
||||||
|
documentation](docs/consensus.md).
|
||||||
|
|
||||||
### Docker
|
### Docker
|
||||||
|
|
||||||
By default the `CMD` is set to run a node on `privnet`, so to do this simply run:
|
By default the `CMD` is set to run a node on `privnet`, so to do this simply run:
|
||||||
|
|
|
@ -1,9 +1,128 @@
|
||||||
# NEO-GO consensus node
|
# NEO-GO consensus node
|
||||||
|
|
||||||
Neo-go node can act as a consensus node.
|
NeoGo node can act as a consensus node. A consensus node differs from regular
|
||||||
It uses pure Go dBFT implementation from [nspcc-dev/dbft](https://github.com/nspcc-dev/dbft).
|
one in that it participates in block acceptance process using dBFT
|
||||||
|
protocol. Any committee node can also be elected as CN therefore they're
|
||||||
|
expected to follow the same setup process as CNs (to be ready to become CNs
|
||||||
|
if/when they're elected).
|
||||||
|
|
||||||
## How to start your own privnet with neo-go nodes
|
While regular nodes on Neo network don't need any special keys CNs always have
|
||||||
|
one used to sign dBFT messages and blocks. So the main difference between
|
||||||
|
regular node and consensus/committee node is that it should be configured to
|
||||||
|
use some key from some wallet.
|
||||||
|
|
||||||
|
## Running a CN on public networks
|
||||||
|
|
||||||
|
### Hardware requirements
|
||||||
|
|
||||||
|
While NeoGo can be very conservative with its resource consumption, public
|
||||||
|
network CN provides some service to the general audience and thus should have
|
||||||
|
enough hardware resources to do its job reliably. We recommend amd64 machine
|
||||||
|
with at least two cores, 8+ GB of memory and 64 GB SSD (disk space
|
||||||
|
requirements depend on actual chain height and
|
||||||
|
KeepOnlyLatestState/RemoveUntraceableBlocks settings, 64 GB is considered to
|
||||||
|
be enough for the first year of blockchain).
|
||||||
|
|
||||||
|
### OS requirements
|
||||||
|
|
||||||
|
NeoGo is a single binary that can be run on any modern GNU/Linux
|
||||||
|
distribution. We recommend using major well-supported OSes like CentOS, Debian
|
||||||
|
or Ubuntu, make sure they're updated with the latest security patches.
|
||||||
|
|
||||||
|
No additional packages are needed for NeoGo CN.
|
||||||
|
|
||||||
|
### Installation
|
||||||
|
|
||||||
|
Download NeoGo binary [from
|
||||||
|
Github](https://github.com/nspcc-dev/neo-go/releases) or use [Docker
|
||||||
|
image](https://hub.docker.com/r/nspccdev/neo-go). It has everything included,
|
||||||
|
no additional plugins needed.
|
||||||
|
|
||||||
|
Take appropriate (mainnet/testnet) configuration [from the
|
||||||
|
repository](https://github.com/nspcc-dev/neo-go/tree/master/config) and save
|
||||||
|
in some directory (we'll assume that it's available in the same directory as
|
||||||
|
neo-go binary).
|
||||||
|
|
||||||
|
### Configuration and execution
|
||||||
|
|
||||||
|
Add the following subsection to `ApplicationConfiguration` section of your
|
||||||
|
configuration file (`protocol.mainnet.yml` or `protocol.testnet.yml`):
|
||||||
|
```
|
||||||
|
UnlockWallet:
|
||||||
|
Path: "wallet.json"
|
||||||
|
Password: "welcometotherealworld"
|
||||||
|
```
|
||||||
|
where `wallet.json` is a path to your NEP-6 wallet and `welcometotherealworld`
|
||||||
|
is a password to your CN key. Run the node in a regular way after that:
|
||||||
|
|
||||||
|
```
|
||||||
|
$ neo-go node --mainnet --config-path ./
|
||||||
|
```
|
||||||
|
where `--mainnet` is your network (can be `--testnet` for testnet) and
|
||||||
|
`--config-path` is a path to configuration file directory. If the node starts
|
||||||
|
fine it'll be logging events like synchronized blocks. The node doesn't have
|
||||||
|
any interactive CLI, it only outputs logs so you can wrap this command in a
|
||||||
|
systemd service file to run automatically on system startup.
|
||||||
|
|
||||||
|
Notice that the default configuration has RPC and Prometheus services enabled,
|
||||||
|
you can turn them off for security purposes or restrict access to them with a
|
||||||
|
firewall. Carefuly review all other configuration options to see if they meet
|
||||||
|
your expectations. Details on various configuration options (as well as CLI
|
||||||
|
commands) are provided [here](cli.md).
|
||||||
|
|
||||||
|
### Registration
|
||||||
|
|
||||||
|
To register as a candidate use neo-go as CLI command with an external RPC
|
||||||
|
server for it to connect to (for chain data and transaction submission). You
|
||||||
|
can use any public RPC server or an RPC server of your own like the node
|
||||||
|
started at previous step. We'll assume that you're running the next command on
|
||||||
|
the same node in default configuration with RPC interface available at port
|
||||||
|
10332.
|
||||||
|
|
||||||
|
Candidate registration is performed via NEO contract invocation that costs
|
||||||
|
1000 GAS, so your account must have enough of it to pay. You need to provide
|
||||||
|
your wallet and address to neo-go command:
|
||||||
|
```
|
||||||
|
$ neo-go wallet candidate register -a NiKEkwz6i9q6gqfCizztDoHQh9r9BtdCNa -w wallet.json -r http://localhost:10332
|
||||||
|
```
|
||||||
|
where `NiKEkwz6i9q6gqfCizztDoHQh9r9BtdCNa` is your address, `wallet.json` is a
|
||||||
|
path to NEP-6 wallet file and `http://localhost:10332` is an RPC node to
|
||||||
|
use.
|
||||||
|
|
||||||
|
This command will create and send appropriate transaction to the network and
|
||||||
|
you should then wait for it to settle in a block. If all goes well it'll end
|
||||||
|
with "HALT" state and your registration will be completed. You can make
|
||||||
|
`getapplicationlog` RPC requests to see transaction status or
|
||||||
|
`getnextblockvalidators` to see if your candidate was added.
|
||||||
|
|
||||||
|
### Voting
|
||||||
|
|
||||||
|
After registration completion if you own some NEO you can also vote for your
|
||||||
|
candidate to help it become CN and receive additional voter GAS. To do that
|
||||||
|
you need to know the public key of your candidate, which can either be seen in
|
||||||
|
`getnextblockvalidators` RPC call output or extracted from wallet `wallet
|
||||||
|
dump-keys` command:
|
||||||
|
|
||||||
|
```
|
||||||
|
$ neo-go wallet dump-keys -w wallet.json
|
||||||
|
NiKEkwz6i9q6gqfCizztDoHQh9r9BtdCNa (simple signature contract):
|
||||||
|
0363f6678ea4c59e292175c67e2b75c9ba7bb73e47cd97cdf5abaf45de157133f5
|
||||||
|
```
|
||||||
|
|
||||||
|
`0363f6678ea4c59e292175c67e2b75c9ba7bb73e47cd97cdf5abaf45de157133f5` is a
|
||||||
|
public key for `NiKEkwz6i9q6gqfCizztDoHQh9r9BtdCNa` address. To vote for it
|
||||||
|
use:
|
||||||
|
```
|
||||||
|
$ neo-go wallet candidate vote -a NiKEkwz6i9q6gqfCizztDoHQh9r9BtdCNa -w wallet.json -r http://localhost:10332 -c 0363f6678ea4c59e292175c67e2b75c9ba7bb73e47cd97cdf5abaf45de157133f5
|
||||||
|
|
||||||
|
```
|
||||||
|
where `NiKEkwz6i9q6gqfCizztDoHQh9r9BtdCNa` is voter's address, `wallet.json`
|
||||||
|
is NEP-6 wallet file path, `http://localhost:10332` is RPC node address and
|
||||||
|
`0363f6678ea4c59e292175c67e2b75c9ba7bb73e47cd97cdf5abaf45de157133f5` is a
|
||||||
|
public key voter votes for. This command also returns transaction hash and you
|
||||||
|
need to wait for this transaction to be accepted into one of subsequent blocks.
|
||||||
|
|
||||||
|
## Private NeoGo network
|
||||||
### Using existing Dockerfile
|
### Using existing Dockerfile
|
||||||
|
|
||||||
neo-go comes with two preconfigured private network setups, the first one has
|
neo-go comes with two preconfigured private network setups, the first one has
|
||||||
|
|
Loading…
Reference in a new issue