-
Notifications
You must be signed in to change notification settings - Fork 3.8k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #1198 from cosmos/bucky/testnets
Bucky/testnets
- Loading branch information
Showing
16 changed files
with
3,531 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,299 @@ | ||
# Connect to a Testnet | ||
|
||
This document explains how to connect to the Testnet of a [Cosmos-SDK](https://github.com/cosmos/cosmos-sdk/) based blockchain. It can be used to connect to the latest Testnet for the Cosmos Hub. | ||
|
||
NOTE: We are aware this documentation is sub-par and are actively working to | ||
improve both the tooling and the documentation to make this as painless as | ||
possible. In the meantime, join the | ||
[chat](https://riot.im/app/#/room/#cosmos_validators:matrix.org) for technical support. Thanks very | ||
much for your patience :) | ||
|
||
## Software Setup (Manual Installation) | ||
|
||
Follow these instructions to install the Cosmos-SDK and connect to the latest Testnet. This instructions work for both a local machine and a VM in a cloud server. | ||
|
||
If you want to run a non-validator full-node, installing the SDK on a Cloud server is a good option. However, if you are want to become a validator for the Hub's `mainnet` you should look at more complex setups, including [Sentry Node Architecture](https://github.com/cosmos/cosmos/blob/master/VALIDATORS_FAQ.md#how-can-validators-protect-themselves-from-denial-of-service-attacks), to protect your node from DDOS and ensure high-availability (see the [technical requirements](https://github.com/cosmos/cosmos/blob/master/VALIDATORS_FAQ.md#technical-requirements)). You can find more information on validators in our [website](https://cosmos.network/validators), in the [Validator FAQ](https://cosmos.network/resources/validator-faq) and in the [Validator Chat](https://riot.im/app/#/room/#cosmos_validators:matrix.org). | ||
|
||
### Install [Go](https://golang.org/) | ||
|
||
Install `go` following the [instructions](https://golang.org/doc/install) in the official golang website. | ||
You will require **Go 1.10+** for this tutorial. | ||
|
||
#### Set GOPATH | ||
|
||
First, you will need to set up your `GOPATH`. Make sure that the location `$HOME` is something like `/Users/<username>`, you can corroborate it by typing `echo $HOME` in your terminal. | ||
|
||
Go to `$HOME` with the command `cd $HOME` and open the the hidden file `.bashrc` with a code editor and paste the following lines \(or `.bash_profile` if your're using OS X\). | ||
|
||
``` | ||
export GOPATH=$HOME/go | ||
export PATH=$PATH:$GOROOT/bin:$GOPATH/bin | ||
``` | ||
|
||
Save and restart the terminal. | ||
|
||
_Note_: If you can't see the hidden file, use the shortcut `Command + Shift + .` in Finder. | ||
|
||
|
||
### Install [GNU Wget](https://www.gnu.org/software/wget/) | ||
|
||
**MacOS** | ||
|
||
``` | ||
brew install wget | ||
``` | ||
|
||
**Linux** | ||
|
||
``` | ||
sudo apt-get install wget | ||
``` | ||
|
||
Note: You can check other available options for downloading `wget` [here](https://www.gnu.org/software/wget/faq.html#download). | ||
|
||
### Install Gaia | ||
|
||
Now we can fetch the correct versions of each dependency by running: | ||
|
||
``` | ||
mkdir -p $GOPATH/src/github.com/cosmos/cosmos-sdk | ||
git clone https://github.com/cosmos/cosmos-sdk.git | ||
git checkout v0.18.0 | ||
make get_tools // run $ make update_tools if already installed | ||
make get_vendor_deps | ||
make install | ||
``` | ||
|
||
This will install the `gaiad` and `gaiacli` binaries. Verify that everything is OK by running: | ||
|
||
``` | ||
gaiad version | ||
``` | ||
|
||
You should see: | ||
|
||
``` | ||
0.18.0-eceb56b7 | ||
``` | ||
|
||
And also: | ||
|
||
``` | ||
gaiacli version | ||
``` | ||
|
||
You should see: | ||
|
||
``` | ||
0.18.0-eceb56b7 | ||
``` | ||
|
||
## Full Node Setup | ||
|
||
Copy the testnet initialization files to a new data directory: | ||
|
||
``` | ||
mkdir -p $HOME/.gaiad/config | ||
cp -a cmd/gaia/testnets/gaia-6001/genesis.json $HOME/.gaiad/config/genesis.json | ||
gaiad unsafe_reset_all | ||
``` | ||
|
||
Add a seed node by changing `seed = ""` in `config.toml` to `seed = "38aa9bec3998f12ae9088b21a2d910d19d565c27@gaia-6001.coinculture.net:46656" | ||
|
||
Lastly change the `moniker` string in the`config.toml`to identify your node. | ||
|
||
``` | ||
# A custom human readable name for this node | ||
moniker = "<your_custom_name>" | ||
``` | ||
|
||
## Upgrading from a previous network | ||
|
||
These instructions are for anyone that ran a previous network and would like to upgrade to a newer version. | ||
|
||
Remove the ephemeral files and reset the data. | ||
``` | ||
rm $HOME/.gaiad/config/addrbook.json $HOME/.gaiad/config/genesis.json | ||
gaiad unsafe_reset_all | ||
``` | ||
|
||
Now your node is in a prestine state without changing your validator key. If you had any | ||
sentry nodes or full nodes setup correctly previously they should work. | ||
|
||
**Make sure that every node has a unique `priv_validator.json`. Do not copy the `priv_validator.json` from an old node to multiple new nodes. Running two nodes with the same `priv_validator.json` will cause you to double sign.**\ | ||
|
||
|
||
Now it is time to upgrade the software. | ||
``` | ||
cd $GOPATH/src/github.com/cosmos/cosmos-sdk | ||
git fetch --all | ||
git checkout v0.18.0 | ||
make update_tools | ||
make get_vendor_deps | ||
make install | ||
``` | ||
|
||
The next step is to copy the new genesis file: | ||
|
||
``` | ||
cp -a cmd/gaia/testnets/gaia-6001/genesis.json $HOME/.gaiad/config/genesis.json | ||
``` | ||
|
||
The last step is the adjust the `config.toml`. Make sure that you are connected to healthy peers or seed nodes. | ||
These are some seeds nodes and they can be put into the config under the `seeds` key. Alternatively you can also | ||
ask user validators directly for a persistent peer and add it under the `persisent_peers` key. | ||
|
||
``` | ||
38aa9bec3998f12ae9088b21a2d910d19d565c27@gaia-6001.coinculture.net:46656" | ||
``` | ||
|
||
## Run a Full Node | ||
|
||
Start the full node: | ||
|
||
``` | ||
gaiad start | ||
``` | ||
|
||
Check the everything is running smoothly: | ||
|
||
``` | ||
gaiacli status | ||
``` | ||
|
||
## Generate keys | ||
|
||
You'll need a private and public key pair \(a.k.a. `sk, pk` respectively\) to be able to receive funds, send txs, bond tx, etc. | ||
|
||
To generate your a new key \(default _ed25519_ elliptic curve\): | ||
|
||
``` | ||
gaiacli keys add <your_key_name> | ||
``` | ||
|
||
Next, you will have to enter a passphrase for your key twice. Save the _seed_ _phrase_ in a safe place in case you forget the password. | ||
|
||
Now if you check your private keys you will see the `<your_key_name>` key among them: | ||
|
||
``` | ||
gaiacli keys show <your_key_name> | ||
``` | ||
|
||
You can see all your other available keys by typing: | ||
|
||
``` | ||
gaiacli keys list | ||
``` | ||
|
||
The validator pubkey from your node should be the same as the one printed with the command: | ||
|
||
``` | ||
gaiad tendermint show_validator | ||
``` | ||
|
||
Finally, save your address and pubkey into a variable to use them afterwards. | ||
|
||
``` | ||
MYADDR=<your_newly_generated_address> | ||
MYPUBKEY=<your_newly_generated_public_key> | ||
``` | ||
|
||
**IMPORTANT:** We strongly recommend to **NOT** use the same passphrase for your different keys. The Tendermint team and the Interchain Foundation will not be responsible for the lost of funds. | ||
|
||
### Get coins | ||
|
||
The best way to get coins at the moment is to ask in Riot chat. We plan to have a reliable faucet in future testnets. | ||
|
||
## Send tokens | ||
|
||
``` | ||
gaiacli send --amount=1000fermion --chain-id=<name_of_testnet_chain> --sequence=0 --name=<key_name> --to=<destination_address> | ||
``` | ||
|
||
The `--amount` flag defines the corresponding amount of the coin in the format `--amount=<value|coin_name>` | ||
|
||
The `--sequence` flag corresponds to the sequence number to sign the tx. | ||
|
||
Now check the destination account and your own account to check the updated balances \(by default the latest block\): | ||
|
||
``` | ||
gaiacli account <destination_address> | ||
gaiacli account <your_address> | ||
``` | ||
|
||
You can also check your balance at a given block by using the `--block` flag: | ||
|
||
``` | ||
gaiacli account <your_address> --block=<block_height> | ||
``` | ||
|
||
## Run a Validator Node | ||
|
||
[Validators](https://cosmos.network/validators) are actors from the network that are responsible from committing new blocks to the blockchain by submitting their votes. In terms of security, validators' stake is slashed in all the zones they belong if they become unavailable, double sign a transaction, or don't cast their votes. We strongly recommend entities intending to run validators in the Cosmos Hub's `mainnet` to check the [technical requirements](https://github.com/cosmos/cosmos/blob/master/VALIDATORS_FAQ.md#technical-requirements) and take the necessary precautions to ensure high-availability, such as setting a Sentry Node architecture. If you have any question about validators, read the [Validator FAQ](https://cosmos.network/resources/validator-faq) and join the [Validator Chat](https://riot.im/app/#/room/#cosmos_validators:matrix.org). | ||
|
||
This section covers the instructions necessary to stake tokens to become a testnet validator candidate. | ||
|
||
Your `pubkey` can be used to create a new validator candidate by staking some tokens: | ||
|
||
You can find your node pubkey by running | ||
``` | ||
gaiad tendermint show_validator | ||
``` | ||
|
||
and this returns your public key for the declare-candidate command | ||
|
||
|
||
``` | ||
gaiacli stake create-validator --amount=500steak --pubkey=<your_node_pubkey> --address-candidate=<your_address> --moniker=satoshi --chain-id=<name_of_the_testnet_chain> --sequence=1 --name=<key_name> | ||
``` | ||
|
||
You can add more information of the validator candidate such as`--website`, `--keybase-sig `or additional `--details`. If you want to edit the candidate info: | ||
|
||
``` | ||
gaiacli stake edit-validator --details="To the cosmos !" --website="https://cosmos.network" | ||
``` | ||
|
||
Finally, you can check all the candidate information by typing: | ||
|
||
``` | ||
gaiacli stake validator --address-candidate=<your_address> --chain-id=<name_of_the_testnet_chain> | ||
``` | ||
|
||
To check that the validator is active you can find it on the validator set list: | ||
|
||
``` | ||
gaiacli advanced tendermint validator-set | ||
``` | ||
|
||
**Note:** Remember that to be in the validator set you need to have more total power than the Xnd validator, where X is the assigned size for the validator set \(by default _`X = 100`_\). | ||
|
||
## Delegate your tokens | ||
|
||
You can delegate \(_i.e._ bind\) **Atoms** to a validator to become a [delegator](https://cosmos.network/resources/delegators) and obtain a part of its fee revenue in **Photons**. For more information about the Cosmos Token Model, refer to our [whitepaper](https://github.com/cosmos/cosmos/raw/master/Cosmos_Token_Model.pdf). | ||
|
||
### Bond your tokens | ||
|
||
Bond your tokens to a validator candidate with the following command: | ||
|
||
``` | ||
gaiacli stake delegate --amount=10steak --address-delegator=<your_address> --address-candidate=<bonded_validator_address> --name=<key_name> --chain-id=<name_of_testnet_chain> --sequence=2 | ||
``` | ||
|
||
When tokens are bonded, they are pooled with all the other bonded tokens in the network. Validators and delegators obtain shares that represent their stake in this pool. | ||
|
||
### Unbond | ||
|
||
If for any reason the validator misbehaves or you just want to unbond a certain amount of the bonded tokens: | ||
|
||
``` | ||
gaiacli stake unbond --address-delegator=<your_address> --address-candidate=<bonded_validator_address> --shares=MAX --name=<key_name> --chain-id=<name_of_testnet_chain> --sequence=3 | ||
``` | ||
|
||
You can unbond a specific amount of`shares`\(eg:`12.1`\) or all of them \(`MAX`\). | ||
|
||
You should now see the unbonded tokens reflected in your balance and in your delegator bond: | ||
|
||
``` | ||
gaiacli account <your_address> | ||
gaiacli stake delegation --address-delegator=<your_address> --address-candidate=<bonded_validator_address> --chain-id=<name_of_testnet_chain> | ||
``` |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,74 @@ | ||
# TESTNET STATUS | ||
|
||
## *June 10, 2018, 8:30 EST* - Gaia-6001 consensus failure | ||
|
||
- Validator unbonding and revocation activity caused a consensus failure | ||
- There is a bug in the staking module that must be fixed | ||
- The team is taking its time to look into this and release a fix following a | ||
proper protocol for hotfix upgrades to the testnet | ||
- Please stay tuned! | ||
|
||
## *June 9, 2018, 14:00 EST* - New Release | ||
|
||
- Released gaia | ||
[v0.18.0](https://github.com/cosmos/cosmos-sdk/releases/tag/v0.18.0) with | ||
update for Tendermint | ||
[v0.20.0](https://github.com/tendermint/tendermint/releases/tag/v0.20.0) | ||
- Includes bug fix for declaring candidacy from the command line | ||
|
||
## *June 8, 2018, 23:30 EST* - Gaia-6001 is making blocks | ||
|
||
- +2/3 of the voting power is finally online for Gaia-6001 and it is making | ||
blocks! | ||
- This is a momentous achievement - a successful asynchronous decentralized | ||
testnet launch | ||
- Congrats everyone! | ||
|
||
## *June 8, 2018, 12:00 EST* - New Testnet Gaia-6001 | ||
|
||
- After some confusion around testnet deployment and a contention testnet | ||
hardfork, a new genesis file and network was released for `gaia-6001` | ||
|
||
## *June 7, 2018, 9:00 EST* - New Testnet Gaia-6000 | ||
|
||
- Released a new `genesis.json` file for `gaia-6000` | ||
- Initial validators include those that were most active in | ||
the gaia-5001 testnet | ||
- Join the network via gaia `v0.18.0-rc0` | ||
|
||
## *June 5, 2018, 21:00 EST* - New Release | ||
|
||
- Released gaia | ||
[v0.17.5](https://github.com/cosmos/cosmos-sdk/releases/tag/v0.17.5) | ||
with update for Tendermint | ||
[v0.19.9](https://github.com/tendermint/tendermint/releases/tag/v0.19.9) | ||
- Fixes many bugs! | ||
- evidence gossipping | ||
- mempool deadlock | ||
- WAL panic | ||
- memory leak | ||
- Please update to this to put a stop to the rampant invalid evidence gossiping | ||
:) | ||
|
||
## *May 31, 2018, 14:00 EST* - New Release | ||
|
||
- Released gaia | ||
[v0.17.4](https://github.com/cosmos/cosmos-sdk/releases/tag/v0.17.4) with update for Tendermint v0.19.7 | ||
- Fixes a WAL bug and some more | ||
- Please update to this if you have trouble restarting a node | ||
|
||
## *May 31, 2018, 2:00 EST* - Testnet Halt | ||
|
||
- A validator equivocated last week and Evidence is being rampantly gossipped | ||
- Peers that can't process the evidence (either too far behind or too far ahead) are disconnecting from the peers that | ||
sent it, causing high peer turn-over | ||
- The high peer turn-over may be causing a memory-leak, resulting in some nodes | ||
crashing and the testnet halting | ||
- We need to fix some issues in the EvidenceReactor to address this and also | ||
investigate the possible memory-leak | ||
|
||
## *May 29, 2018* - New Release | ||
|
||
- Released v0.17.3 with update for Tendermint v0.19.6 | ||
- Fixes fast-sync bug | ||
- Please update to this to sync with the testnet |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
{ | ||
"node_id": "1ebc5ca705b3ae1c06a0888ff1287ada82149dc3", | ||
"ip": "138.68.77.24", | ||
"validator": { | ||
"pub_key": { | ||
"type": "AC26791624DE60", | ||
"value": "TZTQnfqOsi89SeoXVnIw+tnFJnr4X8qVC0U8AsEmFk4=" | ||
}, | ||
"power": 100, | ||
"name": "adrian" | ||
}, | ||
"app_gen_tx": { | ||
"name": "default", | ||
"address": "D9C12CB5186FE0018179742FD3110EE534C63460", | ||
"pub_key": { | ||
"type": "AC26791624DE60", | ||
"value": "TZTQnfqOsi89SeoXVnIw+tnFJnr4X8qVC0U8AsEmFk4=" | ||
} | ||
} | ||
} |
Oops, something went wrong.