-
Notifications
You must be signed in to change notification settings - Fork 716
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
docs: Updates for Gaia v14 (aka v14.1.0) #2839
Merged
Merged
Changes from all commits
Commits
Show all changes
2 commits
Select commit
Hold shift + click to select a range
File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
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
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,14 @@ | ||
|
||
# System requirements | ||
|
||
The Gaia application typically needs at least 32GB RAM for smooth operation. | ||
|
||
If you have less than 32GB RAM, you might try creating a swapfile to swap an idle program onto the hard disk to free up memory. This can allow your machine to run the binary than it could run in RAM alone. | ||
|
||
```shell | ||
# Linux instructions | ||
sudo fallocate -l 16G /swapfile | ||
sudo chmod 600 /swapfile | ||
sudo mkswap /swapfile | ||
sudo swapon /swapfile | ||
``` |
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
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
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 |
---|---|---|
|
@@ -7,7 +7,7 @@ title: Joining Testnet | |
|
||
This tutorial will provide all necessary instructions for joining the current public testnet. If you're interested in more advanced configuration and synchronization options, see [Join Mainnet](./join-mainnet.md) for a detailed walkthrough. | ||
|
||
* Current Version: v13 | ||
* Current Version: v14 | ||
* Chain ID: `theta-testnet-001` | ||
|
||
## Background | ||
|
@@ -59,12 +59,14 @@ State Sync is far faster and more efficient than Fast Sync, but Fast Sync offers | |
## Step-by-Step Setup | ||
|
||
The following set of instructions assumes you are logged in as root. | ||
|
||
* You can run the relevant commands from a sudoer account. | ||
* The `/root/` part in service file paths can be changed to `/home/<username>/`. | ||
|
||
### Build Tools | ||
|
||
Install build tools and Go. | ||
|
||
```shell | ||
sudo apt-get update | ||
sudo apt-get install -y make gcc | ||
|
@@ -80,7 +82,8 @@ You will need to install and configure the Gaia binary using the script below. T | |
* For up-to-date endpoints like seeds and state sync RPC servers, visit the [testnets repository](https://github.com/cosmos/testnets/tree/master/public). | ||
|
||
Build the gaiad binary and initialize the chain home folder. | ||
``` | ||
|
||
```shell | ||
cd $HOME | ||
git clone https://github.com/cosmos/gaia | ||
cd gaia | ||
|
@@ -94,7 +97,8 @@ gaiad init <custom_moniker> | |
``` | ||
|
||
Prepare the genesis file. | ||
``` | ||
|
||
```shell | ||
cd $HOME | ||
wget https://github.com/cosmos/testnets/raw/master/public/genesis.json.gz | ||
gzip -d genesis.json.gz | ||
|
@@ -113,8 +117,7 @@ State sync requires you to configure a trust height and trust hash. These depend | |
* Visit a [testnet explorer](https://explorer.theta-testnet.polypore.xyz/) to find the block and hash for the current height - 1000. | ||
* Set these parameters in the code snippet below: `<BLOCK_HEIGHT>` and `<BLOCK_HASH>`. | ||
|
||
|
||
``` | ||
```shell | ||
cd $HOME/.gaia/config | ||
sed -i 's/enable = false/enable = true/' config.toml | ||
sed -i 's/trust_height = 0/trust_height = <BLOCK_HEIGHT>/' config.toml | ||
|
@@ -126,7 +129,7 @@ sed -i 's/rpc_servers = ""/rpc_servers = "http:\/\/state-sync-01.theta-testnet.p | |
|
||
### Cosmovisor Setup (Optional) | ||
|
||
Cosmovisor is a process manager that monitors the governance module for incoming chain upgrade proposals. When a proposal is approved, Cosmovisor can automatically download the new binary, stop the chain binary when it hits the upgrade height, switch to the new binary, and restart the daemon. Cosmovisor can be used with either Fast Sync or State Sync. | ||
Cosmovisor is a process manager that monitors the governance module for incoming chain upgrade proposals. When a proposal is approved, Cosmovisor can automatically download the new binary, stop the chain binary when it hits the upgrade height, switch to the new binary, and restart the daemon. Cosmovisor can be used with either Fast Sync or State Sync. | ||
|
||
The instructions below provide a simple way to sync via Cosmovisor. For more information on configuration, check out the Cosmos SDK's [Cosmovisor documentation](https://github.com/cosmos/cosmos-sdk/tree/main/tools/cosmovisor). | ||
|
||
|
@@ -140,8 +143,9 @@ Cosmovisor requires the creation of the following directory structure: | |
└── gaiad | ||
``` | ||
|
||
Install Cosmovisor and copy Gaia binary to genesis folder | ||
``` | ||
Install Cosmovisor and copy Gaia binary to genesis folder: | ||
|
||
```shell | ||
go install cosmossdk.io/tools/cosmovisor/cmd/[email protected] | ||
mkdir -p ~/.gaia/cosmovisor/genesis/bin | ||
cp ~/go/bin/gaiad ~/.gaia/cosmovisor/genesis/bin/ | ||
|
@@ -151,11 +155,11 @@ cp ~/go/bin/gaiad ~/.gaia/cosmovisor/genesis/bin/ | |
|
||
* Cosmos Hub recommends running `gaiad` or `cosmovisor` with the `--x-crisis-skip-assert-invariants` flag. If checking for invariants, operators are likely to see `rounding error withdrawing rewards from validator`. These are expected. For more information see [Verify Mainnet](./join-mainnet.md#verify-mainnet). | ||
|
||
|
||
Create one of the following service files. | ||
|
||
If you are not using Cosmovisor: `/etc/systemd/system/gaiad.service` | ||
``` | ||
|
||
```toml | ||
[Unit] | ||
Description=Gaia service | ||
After=network-online.target | ||
|
@@ -171,7 +175,8 @@ WantedBy=multi-user.target | |
``` | ||
|
||
If you are using Cosmovisor: `/etc/systemd/system/cosmovisor.service` | ||
``` | ||
|
||
```toml | ||
[Unit] | ||
Description=Cosmovisor service | ||
After=network-online.target | ||
|
@@ -195,19 +200,22 @@ WantedBy=multi-user.target | |
### Start the Service | ||
|
||
Reload the systemd manager configuration. | ||
``` | ||
|
||
```shell | ||
systemctl daemon-reload | ||
systemctl restart systemd-journald | ||
``` | ||
|
||
If you are not using Cosmovisor: | ||
``` | ||
|
||
```shell | ||
systemctl enable gaiad.service | ||
systemctl start gaiad.service | ||
``` | ||
|
||
If you are using Cosmovisor: | ||
``` | ||
|
||
```shell | ||
systemctl enable cosmovisor.service | ||
systemctl start cosmovisor.service | ||
``` | ||
|
@@ -228,10 +236,11 @@ Follow these instructions if you have a node that is already synced and wish to | |
When the chain reaches the upgrade block height specified by a software upgrade proposal, the chain binary will halt and expect the new binary to be run (the system log will show `ERR UPGRADE "<Upgrade name>" NEEDED at height: XXXX` or something similar). | ||
|
||
There are three ways you can update the binary: | ||
|
||
1. Without Cosmovisor: You must build or download the new binary ahead of the upgrade. When the chain binary halts at the upgrade height: | ||
* Stop the gaiad service with `systemctl stop gaiad.service`. | ||
* Build or download the new binary, replacing the existing `~/go/bin` one. | ||
* Start the gaiad service with `systemctl start gaiad.service`. | ||
* Stop the gaiad service with `systemctl stop gaiad.service`. | ||
* Build or download the new binary, replacing the existing `~/go/bin` one. | ||
* Start the gaiad service with `systemctl start gaiad.service`. | ||
2. With Cosmovisor: You must build or download the new binary and copy it to the appropriate folder ahead of the upgrade. | ||
3. With Cosmovisor: Using the auto-download feature, assuming the proposal includes the binaries for your system architecture. | ||
|
||
|
@@ -253,12 +262,14 @@ If the environment variable `DAEMON_ALLOW_DOWNLOAD_BINARIES` is set to `false`, | |
``` | ||
|
||
Prepare the upgrade directory | ||
``` | ||
|
||
```shell | ||
mkdir -p ~/.gaia/cosmovisor/upgrades/v14/bin | ||
``` | ||
|
||
Download and install the new binary version. | ||
``` | ||
|
||
```shell | ||
cd $HOME/gaia | ||
git pull | ||
git checkout v14.0.0-rc0 | ||
|
Oops, something went wrong.
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is done by most if not all OSs automatically and the swap file is scaled according to needs.
Can you elaborate why this is needed?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This is in all the previous migration updates. For this release I've split out the requirements into a separate doc as I want to reduce the material we repeat in different locations.