Skip to content

Commit

Permalink
Merge pull request #22 from InjectiveLabs/f/10005-chain-upgrade
Browse files Browse the repository at this point in the history
Draft 10005-rc1 upgrade guide
  • Loading branch information
albertchon authored Apr 6, 2022
2 parents f1da6c0 + e4dc615 commit b29fcdf
Show file tree
Hide file tree
Showing 2 changed files with 105 additions and 0 deletions.
1 change: 1 addition & 0 deletions docs/migration/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -7,3 +7,4 @@ This directory contains major upgrade migration instructions.
- [Upgrading from `injective-canonical-chain-2` to `injective-canonical-chain-3`](injective-canonical-chain-3.md)
- [Upgrading from `injective-canonical-chain-3` to `injective-canonical-chain-4`](injective-canonical-chain-4.md)
- [Upgrading from `injective-canonical-chain-4` to `injective-canonical-chain-4` patch](injective-canonical-chain-4-patch.md)
- [Upgrading from `injective-canonical-chain-4` patch to `injective-canonical-chain-5`](injective-canonical-chain-5.md)
104 changes: 104 additions & 0 deletions docs/migration/injective-canonical-chain-5.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,104 @@
# Injective Chain Upgrade Instructions

The following document describes the necessary steps involved that validators and full node operators
must take in order to upgrade the Injective Chain from 10004-rc1 [patch version 10004-rc1-1645352045](https://github.com/InjectiveLabs/injective-chain-releases/releases/tag/v1.4.0-1645352045) to [10005-rc1](https://github.com/InjectiveLabs/injective-chain-releases/releases/tag/v1.5.0-1649280277). The upgrade will take place via an on-chain software upgrade proposal passed by the Injective Chain governance.
If passed, this proposal would commit the Injective Mainnet to halting the 10004-rc1 `injectived` application binary at approximately 14:00 UTC on April 11th 2022 and starting the application binary for the 10005-rc1 `injectived` application binary for the upgraded Injective Chain.

In case of a failed migration via the upgrade module, the Injective Labs team will post an official `injective-canonical-chain-5` genesis file, but it is recommended that validators should do try to export the genesis on their own node to verify the resulting genesis file.

Following proposal <proposal_number>, this indicates that the upgrade procedure should be performed on block number `9614200`.

- [Summary](#summary)
- [Risks](#risks)
- [Recovery](#recovery)
- [Upgrade Procedure](#upgrade-procedure)
- [Notes for Service Providers](#notes-for-DEX-relayer-providers)

# Summary

The Injective Chain 10004-rc1 will undergo a scheduled upgrade to Injective Chain 10005-rc1 release on **14:00 UTC on April 11th 2022**.

The following is a short summary of the upgrade steps:

1. Vote and wait until the node panics at block height 9614200.
2. Backing up configs, data, and keys used for running the Injective Chain.
3. Install the [Injective Chain 10005-rc1 release](https://github.com/InjectiveLabs/injective-chain-releases/releases/tag/v1.5.0-1649280277)
4. Start your node with the new injectived binary to fulfill the upgrade.

Upgrade coordination and support for validators will be available on the #mainnet-validators private channel of the [Injective Discord](https://discord.gg/injective).

The network upgrade can take the following potential pathways:
1. Happy path
Validators successfully migrate from the 10004-rc1 Injective Chain to 10005-rc1 without purging the blockchain history and all validators are up within 1-2 hours of the scheduled upgrade.

2. Not-so-happy path
Validators have trouble upgrading the chain. This could be some consensus breaking changes not covered in upgrade handler, or compatibility issue of the migrated state with new injectived binary, but validators can at least export the genesis.

3. Abort path
In the rare event that the team becomes aware of unnoticed critical issues, the Injective team will attempt to patch all the breaking states and provide another official binary within 36 hours.
If the chain is not successfully resumed within 36 hours, the upgrade will be announced as aborted on the #mainnet-validators channel of [Discord](https://discord.gg/injective), and validators will need to resume running the Injective chain without any updates or changes. A new governance proposal for the upgrade will need to be issued and voted on by the community for the next upgrade.

## Risks

As a validator performing the upgrade procedure on your consensus nodes carries a heightened risk of
double-signing and being slashed. The most important piece of this procedure is verifying your
software version and genesis file hash before starting your validator and signing.

The riskiest thing a validator can do is discover that they made a mistake and repeat the upgrade
procedure again during the network startup. If you discover a mistake in the process, the best thing
to do is wait for the network to start before correcting it. If the network is halted and you have
started with a different genesis file than the expected one, seek advice from an Injective developer
before resetting your validator.

## Recovery

Prior to exporting the Injective Chain state, validators are encouraged to take a full data snapshot at the
export height before proceeding. Snapshotting depends heavily on infrastructure, but generally this
can be done by backing up the `.injectived` directory. We would suggest using `aws s3 sync` with delete flag, this will shorten the snapshotting time as only the file diffs are uploaded to the S3 bucket.

It is critically important to backup the `.injectived/data/priv_validator_state.json` file after stopping your injectived process. This file is updated every block as your validator participates in a consensus rounds. It is a critical file needed to prevent double-signing, in case the upgrade fails and the previous chain needs to be restarted.

In the event that the upgrade does not succeed, validators and operators must restore the snapshot and downgrade back to
10004-rc1 [patch version 10004-rc1-1645352045](https://github.com/InjectiveLabs/injective-chain-releases/releases/tag/v1.4.0-1645352045) and continue the chain until next upgrade announcement.

## Upgrade Procedure

1. Verify you are currently running the correct (pre-upgrade) version (`94583db`) of `injectived`:
```
bash
$ injectived version
Version dev (94583db)
Compiled at 20220123-0855 using Go go1.17.6 (amd64)
```

2. After the chain has halted, make a backup of your `.injectived` directory
```bash
cp ~/.injectived ./injectived-backup
```
**NOTE**: It is recommended for validators and operators to take a full data snapshot at the export
height before proceeding in case the upgrade does not go as planned or if not enough voting power
comes online in a sufficient and agreed upon amount of time. In such a case, the chain will fallback
to continue operating the existing Canonical Chain. See [Recovery](#recovery) for details on how to proceed.

3. Download and install the Injective Chain 10005-rc1 release
```bash
wget https://github.com/InjectiveLabs/injective-chain-releases/releases/download/v1.5.0-1649280277/linux-amd64.zip
unzip linux-amd64.zip
sudo mv injectived /usr/bin
```

4. Verify you are currently running the correct new version (`568ce23`) of `injectived` after downloading the 10005-rc1 release:
```bash
$ injectived version
Version dev (568ce23)
Compiled at 20220406-2125 using Go go1.18 (amd64)
```

5. Coordinate to restart your injectived with other validators
```bash
injectived start
```
The binary will perform the upgrade automatically and continue the next consensus round if everything goes well.

## Notes for DEX relayer providers
Relayer upgrade will be available after the chain is successfully upgraded as it relies on several other components that work with injectived.

0 comments on commit b29fcdf

Please sign in to comment.