2018-01-09 20:35:47 +00:00
|
|
|
# Tendermint
|
|
|
|
|
|
|
|
## Overview
|
|
|
|
|
2018-04-09 15:42:19 +02:00
|
|
|
This is a quick start guide. If you have a vague idea about how Tendermint
|
|
|
|
works and want to get started right away, continue. Otherwise, [review the
|
|
|
|
documentation](http://tendermint.readthedocs.io/en/master/).
|
2018-01-09 20:35:47 +00:00
|
|
|
|
|
|
|
## Install
|
|
|
|
|
|
|
|
### Quick Install
|
|
|
|
|
2018-05-17 10:05:59 -04:00
|
|
|
On a fresh Ubuntu 16.04 machine can be done with [this script](https://git.io/vpgEI), like so:
|
2018-01-09 20:35:47 +00:00
|
|
|
|
|
|
|
```
|
2018-05-17 10:05:59 -04:00
|
|
|
curl -L https://git.io/vpgEI | bash
|
2018-01-09 20:35:47 +00:00
|
|
|
source ~/.profile
|
|
|
|
```
|
|
|
|
|
|
|
|
WARNING: do not run the above on your local machine.
|
|
|
|
|
|
|
|
The script is also used to facilitate cluster deployment below.
|
|
|
|
|
|
|
|
### Manual Install
|
|
|
|
|
2018-01-20 14:54:59 -05:00
|
|
|
Requires:
|
2018-05-17 10:05:59 -04:00
|
|
|
- `go` minimum version 1.10
|
2018-01-20 14:54:59 -05:00
|
|
|
- `$GOPATH` environment variable must be set
|
|
|
|
- `$GOPATH/bin` must be on your `$PATH` (see https://github.com/tendermint/tendermint/wiki/Setting-GOPATH)
|
2018-01-09 20:35:47 +00:00
|
|
|
|
|
|
|
To install Tendermint, run:
|
|
|
|
|
|
|
|
```
|
|
|
|
go get github.com/tendermint/tendermint
|
|
|
|
cd $GOPATH/src/github.com/tendermint/tendermint
|
2018-01-20 14:54:59 -05:00
|
|
|
make get_tools && make get_vendor_deps
|
2018-01-09 20:35:47 +00:00
|
|
|
make install
|
|
|
|
```
|
|
|
|
|
2018-01-20 14:54:59 -05:00
|
|
|
Note that `go get` may return an error but it can be ignored.
|
|
|
|
|
2018-01-09 20:35:47 +00:00
|
|
|
Confirm installation:
|
|
|
|
|
|
|
|
```
|
|
|
|
$ tendermint version
|
2018-04-09 15:42:19 +02:00
|
|
|
0.18.0-XXXXXXX
|
2018-01-09 20:35:47 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
## Initialization
|
|
|
|
|
|
|
|
Running:
|
|
|
|
|
|
|
|
```
|
|
|
|
tendermint init
|
|
|
|
```
|
|
|
|
|
|
|
|
will create the required files for a single, local node.
|
|
|
|
|
|
|
|
These files are found in `$HOME/.tendermint`:
|
|
|
|
|
|
|
|
```
|
|
|
|
$ ls $HOME/.tendermint
|
|
|
|
|
|
|
|
config.toml data genesis.json priv_validator.json
|
|
|
|
```
|
|
|
|
|
|
|
|
For a single, local node, no further configuration is required.
|
|
|
|
Configuring a cluster is covered further below.
|
|
|
|
|
|
|
|
## Local Node
|
|
|
|
|
|
|
|
Start tendermint with a simple in-process application:
|
|
|
|
|
|
|
|
```
|
2018-02-27 14:01:10 +00:00
|
|
|
tendermint node --proxy_app=kvstore
|
2018-01-09 20:35:47 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
and blocks will start to stream in:
|
|
|
|
|
|
|
|
```
|
|
|
|
I[01-06|01:45:15.592] Executed block module=state height=1 validTxs=0 invalidTxs=0
|
|
|
|
I[01-06|01:45:15.624] Committed state module=state height=1 txs=0 appHash=
|
|
|
|
```
|
|
|
|
|
|
|
|
Check the status with:
|
|
|
|
|
|
|
|
```
|
2018-06-12 02:25:52 -07:00
|
|
|
curl -s localhost:26657/status
|
2018-01-09 20:35:47 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
### Sending Transactions
|
|
|
|
|
2018-02-27 14:01:10 +00:00
|
|
|
With the kvstore app running, we can send transactions:
|
2018-01-09 20:35:47 +00:00
|
|
|
|
|
|
|
```
|
2018-06-12 02:25:52 -07:00
|
|
|
curl -s 'localhost:26657/broadcast_tx_commit?tx="abcd"'
|
2018-01-09 20:35:47 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
and check that it worked with:
|
|
|
|
|
|
|
|
```
|
2018-06-12 02:25:52 -07:00
|
|
|
curl -s 'localhost:26657/abci_query?data="abcd"'
|
2018-01-09 20:35:47 +00:00
|
|
|
```
|
|
|
|
|
2018-01-20 14:54:59 -05:00
|
|
|
We can send transactions with a key and value too:
|
2018-01-09 20:35:47 +00:00
|
|
|
|
|
|
|
```
|
2018-06-12 02:25:52 -07:00
|
|
|
curl -s 'localhost:26657/broadcast_tx_commit?tx="name=satoshi"'
|
2018-01-09 20:35:47 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
and query the key:
|
|
|
|
|
|
|
|
```
|
2018-06-12 02:25:52 -07:00
|
|
|
curl -s 'localhost:26657/abci_query?data="name"'
|
2018-01-09 20:35:47 +00:00
|
|
|
```
|
|
|
|
|
|
|
|
where the value is returned in hex.
|
|
|
|
|
|
|
|
## Cluster of Nodes
|
|
|
|
|
2018-04-09 15:42:19 +02:00
|
|
|
First create four Ubuntu cloud machines. The following was tested on Digital
|
|
|
|
Ocean Ubuntu 16.04 x64 (3GB/1CPU, 20GB SSD). We'll refer to their respective IP
|
|
|
|
addresses below as IP1, IP2, IP3, IP4.
|
2018-01-09 20:35:47 +00:00
|
|
|
|
2018-01-20 14:54:59 -05:00
|
|
|
Then, `ssh` into each machine, and execute [this script](https://git.io/vNLfY):
|
2018-01-09 20:35:47 +00:00
|
|
|
|
|
|
|
```
|
2018-05-17 10:05:59 -04:00
|
|
|
curl -L https://git.io/vpgEI | bash
|
2018-01-09 20:35:47 +00:00
|
|
|
source ~/.profile
|
|
|
|
```
|
|
|
|
|
|
|
|
This will install `go` and other dependencies, get the Tendermint source code, then compile the `tendermint` binary.
|
|
|
|
|
|
|
|
Next, `cd` into `docs/examples`. Each command below should be run from each node, in sequence:
|
|
|
|
|
|
|
|
```
|
2018-06-12 02:25:52 -07:00
|
|
|
tendermint node --home ./node0 --proxy_app=kvstore --p2p.persistent_peers="167b80242c300bf0ccfb3ced3dec60dc2a81776e@IP1:26656,3c7a5920811550c04bf7a0b2f1e02ab52317b5e6@IP2:26656,303a1a4312c30525c99ba66522dd81cca56a361a@IP3:26656,b686c2a7f4b1b46dca96af3a0f31a6a7beae0be4@IP4:26656"
|
|
|
|
tendermint node --home ./node1 --proxy_app=kvstore --p2p.persistent_peers="167b80242c300bf0ccfb3ced3dec60dc2a81776e@IP1:26656,3c7a5920811550c04bf7a0b2f1e02ab52317b5e6@IP2:26656,303a1a4312c30525c99ba66522dd81cca56a361a@IP3:26656,b686c2a7f4b1b46dca96af3a0f31a6a7beae0be4@IP4:26656"
|
|
|
|
tendermint node --home ./node2 --proxy_app=kvstore --p2p.persistent_peers="167b80242c300bf0ccfb3ced3dec60dc2a81776e@IP1:26656,3c7a5920811550c04bf7a0b2f1e02ab52317b5e6@IP2:26656,303a1a4312c30525c99ba66522dd81cca56a361a@IP3:26656,b686c2a7f4b1b46dca96af3a0f31a6a7beae0be4@IP4:26656"
|
|
|
|
tendermint node --home ./node3 --proxy_app=kvstore --p2p.persistent_peers="167b80242c300bf0ccfb3ced3dec60dc2a81776e@IP1:26656,3c7a5920811550c04bf7a0b2f1e02ab52317b5e6@IP2:26656,303a1a4312c30525c99ba66522dd81cca56a361a@IP3:26656,b686c2a7f4b1b46dca96af3a0f31a6a7beae0be4@IP4:26656"
|
2018-01-09 20:35:47 +00:00
|
|
|
```
|
|
|
|
|
2018-04-09 15:42:19 +02:00
|
|
|
Note that after the third node is started, blocks will start to stream in
|
|
|
|
because >2/3 of validators (defined in the `genesis.json`) have come online.
|
|
|
|
Seeds can also be specified in the `config.toml`. See [this
|
|
|
|
PR](https://github.com/tendermint/tendermint/pull/792) for more information
|
|
|
|
about configuration options.
|
2018-01-09 20:35:47 +00:00
|
|
|
|
|
|
|
Transactions can then be sent as covered in the single, local node example above.
|