LogoLogo
  • WELCOME TO ALEPH ZERO
  • EXPLORE
    • About Aleph Zero
    • AlephBFT Consensus
    • The Economy of Aleph Zero
    • Where to Buy AZERO
    • Decentralized Governance on Aleph Zero
    • Ecosystem
    • Aleph Zero Foundation Treasury Management
    • Community
    • Glossary
    • Audit & Research Papers
  • USE
    • Wallets
    • Explorer
    • Ledger
    • Telegram Notifications
    • Aleph Zero Signer
      • General introduction
      • What does Signer do?
      • What are Sub-accounts and Sub-account paths?
      • Why is it critical to store your Secret Phrase in a safe place?
      • How to forget and restore accounts?
      • What are Networks?
      • What are Trusted apps?
    • Dashboard
      • Dashboard basics
      • Overview
    • Stake
      • Staking Basics
      • Staking Menu Overview
      • How to Start Staking with the Aleph Zero Dashboard
      • How to Start Staking With the Developer Wallet
      • How to start staking using Ledger hardware wallet
      • How to Change Nominations
      • How to Stop Staking
      • Staking Rewards
      • Validators
      • Commission and Foundation Nodes
      • Proxy Accounts
    • Validate
      • Validating Overview
      • Hardware requirements
      • Running an Aleph Node on Testnet
        • Downloading and running the node
        • Verifying your setup
        • Customizing your setup
        • Building and running from source [advanced]
          • Building from source
          • Set environment variables
          • Download DB snapshot
          • Running the binary
        • Appendix: Ports, addresses, validators, and archivists
      • Running an Aleph Node on Mainnet
        • Running the node
        • Building and running from source [advanced]
      • Setting your identity
      • Making the node validate
      • Securing your validator
      • Troubleshooting
      • Elections and Rewards Math
      • Testnet Validator Airdrop
      • Foundation Nomination Program
    • Using the EVM-layer
    • Governance
      • Token
      • Multisig Accounts
  • BUILD
    • Aleph Zero smart contracts basics
      • Setting up a Testnet account
      • Installing required tools
      • Creating your first contract
      • Deploying your contract to Aleph Zero Testnet
      • Extending your contract
    • Cross contract calls
      • Using references
      • Using dynamic calls
    • Migrating from Solidity
    • Writing e2e tests with ink-wrapper
    • Aleph Zero Signer integration
    • Front-end app: smart contract interaction
    • Security Course by Kudelski Security
      • ink! Developers Security Guideline
      • Lesson 1 - Getting started with ink!
      • Lesson 2 - Threat Assessment
      • Lesson 3 - Integer Overflow
      • Lesson 4 - Signed-integer
      • Lesson 5 - Role-Based Access Control
      • Lesson 6 - Address Validation
      • Lesson 7 - Smart Contract Control
    • Development on EVM-layer
  • PROTOCOL DETAILS
    • Shielder
      • Overview
      • Design against Bad Actors
      • Preliminaries - ZK-relations
      • Notes and Accounts
      • ZK-ID and Registrars
      • Anonymity Revokers
      • PoW Anonymity Revoking
      • Relayers
      • Deterministic Secret Management
      • SNARK-friendly Symmetric Encryption
      • SNARK-friendly Asymmetric Encryption
      • Cryptography
      • Token shortlist
      • User Wallet
      • Versioning
      • PoC
      • Version 0.1.0
      • Version 0.2.0
    • Common DEX
      • Common Whitepaper - Differences
      • Dutch Auctions
  • FAQ
  • Tutorials
    • Withdrawing coins from exchanges
      • How to withdraw your AZERO coins from KuCoin
      • How to withdraw your AZERO coins from MEXC Global
      • How to withdraw your AZERO coins from HTX
  • Setting up or restoring a wallet
    • How to set up or recover your AZERO account using Aleph Zero Signer
    • How to set up or recover your AZERO account using the official mainnet web wallet
    • How to set up or recover your AZERO account using Nova Wallet
    • How to set up or recover your AZERO account using SubWallet
    • How to set up or recover your AZERO account using Talisman
  • Staking
    • How to stake via a direct nomination using the Aleph Zero Dashboard
    • How to stake via a nomination pool using the Aleph Zero Dashboard
    • How to destroy a nomination pool via the Aleph Zero Dashboard
Powered by GitBook
On this page
  • No-downtime upgrade

Was this helpful?

  1. USE
  2. Validate
  3. Running an Aleph Node on Testnet
  4. Building and running from source [advanced]

Download DB snapshot

Download a database snapshot to run an Aleph node on the testnet for validating transactions.

PreviousSet environment variablesNextRunning the binary

Last updated 1 month ago

Was this helpful?

Create a directory for the data. Note that this will host the chain database, so it has to have access to reasonable amounts of space.

mkdir $BASE_PATH && cd $BASE_PATH

Download the latest DB snapshot from

CHAIN_DIR="chains/testnet/"
mkdir -p $CHAIN_DIR
cd $CHAIN_DIR
wget -q -O - https://azero-snapshots.dev/testnet/rocksdb-pruned.html | tar xzf -

The command above downloads and unpacks the snapshot in one step: it only needs as much storage as the [unpacked] snapshot itself, as it doesn't store the archive. Now we can go back to the previous directory:

cd ../../

Download the chainspec:

version=$(curl --silent https://rest.azero.dev/testnet-version)
wget -O chainspec.json "https://github.com/Cardinal-Cryptography/aleph-node/raw/${version}/bin/node/src/resources/testnet_chainspec.json"

No-downtime upgrade

If you're already running a validator node and would like to switch to using RocksDB, you can use the following steps to keep the downtime during the upgrade to the minimum:

Before you start: ensure that your node has enough space to accommodate an additional 60GB of storage for the new snapshot

  1. Without stopping the node: download the snapshot and unpack it in the same directory where you unpacked the legacy, ParityDB snapshot.

  2. You should end up with two directories: db and paritydb (the latter we will later be able to delete, the former is the new RocksDB database)

  3. Ensure your validator is not in the active committee (the best time for an upgrade is right after your validator has stopped being in the active committee).

  4. Stop your node.

  5. Start your node with pruning enabled (see the Running the binary section).

  6. Now you can remove the paritydb folder to save space.

Congratulations, you're now running a RocksDB validator!

https://azero-snapshots.dev/testnet/rocksdb-pruned.html