Skip to main content

v0.4.1

Overview

This guide provides steps for upgrading to the Warden v0.4.1 release, which integrates Warden with the Skip: Connect oracle service.

The network upgrade will take place on August 13, 2024. The Warden team is going to take the snapshot, export the state, and revert it back if needed.

If you have any outstanding questions, join our Discord.

warning

The upgrade procedure carries heightened risks of double-signing and being slashed. To handle these risks and securely address any issues that may arise during the upgrade, back up your data prior to the upgrade. During the upgrade, follow our tips listed in Security and troubleshooting.

1. Verify & back up

Before starting your validator and signing, do the following:

  • Verify your software version and the genesis file hash.
  • Back up your private node keys.
  • Take a full data snapshot.

The method for taking a snapshot depends on your infrastructure, but generally, you can achieve this by backing up the wardend directory. If you're using Cosmovisor to upgrade, it'll back up your data by default.

warning

After stopping the wardend process, it's critically important to back up the .wardend/data/priv_validator_state.json file.

Note: The priv_validator_state.json file is updated every block as your validator participates in consensus rounds. In case the upgrade fails, and you have to restart the previous chain, you'll need this file to avoid double signing. See Handling node restarts.

2. Run Connect sidecar

Prior to the update, you should also run the Skip:Connect binary on the same machine as wardend. Make sure you enable it from the configuration.

Follow this guide: Operate Connect.

3. Upgrade

Option 1: Use Cosmovisor

To upgrade using Cosmovisor, take these steps:

  1. Download the wardend v0.4.1 binary and put it to $WARDEN_HOME/cosmovisor/upgrades/v03-to-v04/bin:

    mkdir -p  $WARDEN_HOME/cosmovisor/upgrades/v03-to-v04/bin
    cp $(which wardend) $WARDEN_HOME/cosmovisor/upgrades/v03-to-v04/bin

    Note: Alternatively, enable auto-download in Cosmovisor, and it'll automatically download the binary.

  2. Start the node:

    cosmovisor run start --x-crisis-skip-assert-invariants --home $DAEMON_HOME

    Note: We recommend skipping the invariant checks to reduce the upgrade time. Future releases of the Cosmos SDK will include additional improvements to the crisis module.

  3. After reaching the upgrade block height, Warden will panic and stop.

  4. The chain will continue producing blocks when validators with a total sum voting power > 2/3 complete their node upgrades and come back online.

Option 2: Upgrade manually

  1. Download the v0.4.1 wardend binary or build it from the source code. See the installation instructions in the Join Buenavista guide.

  2. Run Warden v0.3.2 until the upgrade height. The node will panic:

    ERR UPGRADE "v0.4.1" NEEDED at height: 1675700: upgrade to v0.4.1 and applying upgrade "v0.4.1" at height: 1675700 
  3. Stop the node and switch the binary to Warden v0.4.1. Restart the node:

    wardend start
  4. The chain will continue producing blocks when validators with a total sum voting power > 2/3 complete their node upgrades and come back online.

Security & troubleshooting

warning

The upgrade procedure carries heightened risks of double-signing and being slashed. To mitigate these risks and securely address any issues that may arise during the upgrade, back up your data prior to the upgrade. During the upgrade, follow the rules listed below.

Handling mistakes

If you discover you've made a mistake, it's not safe to repeat the upgrade procedure during the network startup. Instead, wait for the network to start and then correct the mistake.

Handling node restarts

Your node may restart during the upgrade due to OOM being killed, hardware issues, and other reasons. In this case, it's not safe to proceed with the upgrade. Instead, follow these steps:

  1. Recover your node from a backup.

    When applying a snapshot from the backup, keep your ./data/priv_validator_state.json file. This will help you avoid being slashed due to double signing.

  2. Restart the upgrade process.

Note: If you proceed with the upgrade without recovering your node, the upgrade will likely complete successfully, but you'll get the AppHash error once the network is up.