Running an Archive Node
Overview
An Archive Node is a type of Full Node that stores extended historical data of a blockchain. If you are creating a blockchain explorer or a similar application that requires access to historical data, using an Archive Node as an indexer is recommended.
Hardware requirements
- at least 8 cores CPU
- at least 64 GB RAM
- at least 4TB SSD on your server
- 1 Gbit/s network connectivity
- a public IP address (fixed IP address)
Installation
In general, you need the following steps to run an Archive Node:
- Install ZFS
- Install MyTonCtrl
- Run a Full Node on your server and stop validator process
- Download and restore dump data from https://archival-dump.ton.org
- Run Full Node with Configuring DB specs for Archive Node
Install ZFS
Dumps come in form of ZFS Snapshots compressed using plzip, you need to install zfs on your host and restore the dump, see Oracle Documentation for more details. Before restoring we highly recommend to enable compression on parent ZFS filesystem, this will save you a lot of space.
- Install zfs, create new pool (
data
). - Enable compression:
zfs set compression=lz4 data
- Create volume:
zfs create data/ton-work
Install mytonctrl
Download the installation script. We recommend to install the tool under your local user account, not as Root. In our example a local user account is used:
wget https://raw.githubusercontent.com/ton-blockchain/mytonctrl/master/scripts/install.sh
Run a Full Node
Run the installation script as administrator:
sudo bash install.sh -m full
See more detailed guide in Running Full Node section.
Run an Archive Node
- Before performing a restore, you must stop the validator by running the command:
systemctl stop validator.service
- Make a backup of config files
/var/ton-work/db/config.json
and/var/ton-work/db/keyring
(they will be erased after the recovery process).
mv /var/ton-work /var/ton-work.bak
- Request
user
andpassword
credentials to gain access for downloading dumps in the @TONBaseChatEn Telegram chat. - Tell plzip to use as many cores as your machine allows to speed up extraction process (-n parameter). Another handy tool to use is pipe viewer utility. Here is example command to restore the dump directly from this server via curl:
wget --user <usr> --password <pwd> -c https://archival-dump.ton.org/dumps/latest.zfs.lz | pv | plzip -d | zfs recv ton-pool/db
- Mount zfs:
zfs set mountpoint=/var/ton-work data/ton-work && zfs mount data/ton-work
- Restore config.json, keys and db/keyring from backup to
/var/ton-work
- Fix permissions:
chown -R validator:validator /var/ton-work
- Add storage settings for the node to the file
/etc/systemd/system/validator.service
in theExecStart
line:
--state-ttl 315360000 --archive-ttl 315360000 --block-ttl 315360000
Please be patient once you start the node and observe the logs. Dumps come without DHT caches, so it will take your node some time to find other nodes and then sync with them. Depending on the age of the snapshot, your node might take from a few hours to several days to catch up with the network. This is normal.
- Start the validator by running the command:
systemctl start validator.service
- Open
mytonctrl
and check the node status using the status command.
Node maintenance
Node database requires cleansing from time to time (we advise once a week), to do so please perform following steps as root:
- Stop validator process (Never skip this!)
- Run
find /var/ton-work -name 'LOG.old*' -exec rm {} +
- Run
rm -r /var/ton-work/db/files/packages/temp.archive.*
- Start validator process
Troubleshooting and backups
If for some reason something does not work / breaks you can always roll back to @archstate snapshot on your ZFS filesystem, this is the original state from dump.
If your Node works well then you can remove this snapshot to save storage space, but we do recommend to regularly snapshot your filesystem for rollback purposes because validator node has been known to corrupt data as well as config.json in some cases. zfsnap is a nice tool to automate snapshot rotation.
Have question or problem? Ask in the TON dev chat.