Skip to content

Latest commit

 

History

History
149 lines (95 loc) · 5.79 KB

readme.md

File metadata and controls

149 lines (95 loc) · 5.79 KB

Overview

The goal of this project is to upgrade a running blockchain node which has stopped because of an accepted software upgrade proposal.

You must create an SSH connection from a machine (host computer) to the machine where the node is running (target computer).

All the executions below MUST happen on target computer. Nothing is executed on the host computer itself.

Prerequirements on host computer

SSH Connection to the machine where a CUDOS node is running

Prerequirements on target machine

Enough free space to make a backup. The backup will be as large sa your current CudosData folder.

Docker must be installed

Docker-compose must be installed

JQ must be installed

Git must be installed

Python3 must be installed

Genesal usage

  1. Connect to target computer using SSH
  2. Clone cudos-builders repo somewhere (usually in your home directory)
git clone --branch v1.1.0 https://github.com/CudoVentures/cudos-builders.git CudosBuilders
  1. Create config files according to Config section below
  2. Execute the script according to Usage section below

Config

All of the config files are in ./upgrade/config folder.

Important: Do not leave any comments in any .env file

Step 1

Prepare the node.env based on node.env.example. It contains the following variables:

  1. PARAM_NODE_NAME: the name of the node that is going to be upgraded. Possible values are: root-node, seed-node, sentry-node or full-node. Example: PARAM_NODE_NAME="sentry-node"
  2. PARAM_SOURCE_DIR: A dir where repos were initially cloned during initial setup of the node, usually we use something like "/usr/cudos" Example: PARAM_SOURCE_DIR="/usr/cudos"
  3. PARAM_HAS_ORCHESTRATOR: Optional indicates whether this node has an orchestrator or not. This param is designed for CUDOS orchestrator operator. You can leave it empty if your not sure what this it is about.Example: PARAM_HAS_ORCHESTRATOR="false"

Step 2 (only for nodes with an orchestrator)

Prepare the gravity.env based on gravity.env.example. It contains the following variables:

  1. PARAM_CHAIN_ENDPOINT_26657: Network's endpoint for port 26657. Example: PARAM_CHAIN_ENDPOINT_26657="http://43.14.14.12:26657"
  2. PARAM_ETH_RPC: Address to the ethereum full node. Example: PARAM_ETH_RPC="http://43.14.14.12:8545"
  3. PARAM_CONTRACT_DEPLOYER_ETH_PRIV_KEY: The private key of a wallet that will be used for gravity contract's deployment. Example: PARAM_CONTRACT_DEPLOYER_ETH_PRIV_KEY="ae1341352513513a7f9a9a7a9a9a08a6a4a5f6ea9204135f1f3e1a3b1dae413e"

Usage

There are 3 scripts - node, backup and gravity.

Important: The side effect of executing any of these scripts will be a folder, defined in PARAM_SOURCE_DIR at node.env on target computer

Important: Execute these scripts only when all config files are ready.

Important: All of the scripts below must be executed from ./upgrade folder.

Important: Make sure that ./src/backup.sh, ./src/node.sh and ./src/gravity.sh have execute permission.

Backup

Backup script has four usages:

Create a backup

The command below creates a backup of current source files and data files.

sudo ./src/backup.sh create

Restore a backup

The command restores a backup that has been created using Create a backup

sudo ./src/backup.sh restore

Validate a backup

The command validates whether a created backup using Create a backup is valid

sudo ./src/backup.sh validate

Clean a backup

The command deletes previously created backup using Create a backup

sudo ./src/backup.sh clean

Node

Node script has following usages:

Validate the config/setup

The command check for installed binaries, config files, repos, etc.

sudo ./src/node.sh validate

Perform an upgrade

The command upgrades a node

sudo ./src/node.sh upgrade

Perform an upgrade bypassing the exporting and migrating of the genesis

The command upgrades a node by using an external genesis. This option cannot be used unless the upgraded network has started producing blocks

sudo ./src/node.sh upgrade-with-predefined-genesis

Gravity

Gravity script has following usage:

Change contract

The command changes the network contract and starts an orchestrator

sudo ./src/gravity.sh change-contract

Launch sequence

  1. Create a backup

    Note: Creating of a backup could take a lot of time. It is very important to do it ONCE upgrade hight has been reached NOT before that. Make sure there is no error messages in the console. If something went wrong you can always re-create the backup. Make sure that the backup is correct (You can check it using Validate a backup) before proceeding to the next step.

  2. Validate

    Note: The validate command will print the information about current node. Read it carefully and proceed with the next step only if this information is valid. If it is not valid, please contact CUDOS and make the appropriate changes. If the changes invole any of the previously backup-ed files, you must re-create the backup.

  3. Upgrade

    Note: The upgrade could take up to 20min. If there is any error message during the upgrade you must restore a backup (using Restore a backup) and start over.

  4. Gravity (only for root-nodes and only if the operator of the root node has special instruction to do so!)

    Note: This step MUST NOT be done in production. It deploys a new gravity contract and a new orchestrator. It MUST only be executed if explicitly stated. It MUST be executed when the network has started producing blocks after the upgrade, in other words - when 2/3 of genesis validator are online.