-
Install Docker and Docker-Compose, Aptos CLI.
-
Create a directory for your Aptos node composition. e.g.
export WORKSPACE=testnet mkdir ~/$WORKSPACE cd ~/$WORKSPACE
-
Download the validator.yaml, fullnode.yaml and docker-compose.yaml configuration files into this directory.
wget https://raw.githubusercontent.com/aptos-labs/aptos-core/main/docker/compose/aptos-node/docker-compose.yaml wget https://raw.githubusercontent.com/aptos-labs/aptos-core/main/docker/compose/aptos-node/validator.yaml wget https://raw.githubusercontent.com/aptos-labs/aptos-core/main/docker/compose/aptos-node/fullnode.yaml
-
Generate key pairs (node owner key, consensus key and networking key) in your working directory.
$ aptos genesis generate-keys --output-dir ~/$WORKSPACE
This will create three files:
private-keys.yaml
,validator-identity.yaml
,validator-full-node-identity.yaml
for you. Backup your key files somewhere safe, this is important for you to establish ownership of your node, and it will be used to claim your rewards later if eligible. Very important!! -
Configure validator information, you need to setup a static IP / DNS address which can be used by the node, and make sure the network / firewalls are properly configured to accept external connections.
$ aptos genesis set-validator-configuration \ --keys-dir ~/$WORKSPACE --local-repository-dir ~/$WORKSPACE \ --username <pick a username for your node> \ --validator-host <Validator Node IP / DNS address>:<Port> \ --full-node-host <Full Node IP / DNS address>:<Port> # for example, with IP: $ aptos genesis set-validator-configuration \ --keys-dir ~/$WORKSPACE --local-repository-dir ~/$WORKSPACE \ --username aptosbot \ --validator-host 35.232.235.205:6180 \ --full-node-host 34.135.169.144:6182 # for example, with DNS: $ aptos genesis set-validator-configuration \ --keys-dir ~/$WORKSPACE --local-repository-dir ~/$WORKSPACE \ --username aptosbot \ --validator-host bot.aptosdev.com:6180 \ --full-node-host fn.bot.aptosdev.com:6182
This will create a YAML file in your working directory with your username, e.g.
aptosbot.yml
, it should looks like:--- account_address: 7410973313fd0b5c69560fd8cd9c4aaeef873f869d292d1bb94b1872e737d64f consensus_key: "0x4e6323a4692866d54316f3b08493f161746fda4daaacb6f0a04ec36b6160fdce" account_key: "0x83f090aee4525052f3b504805c2a0b1d37553d611129289ede2fc9ca5f6aed3c" network_key: "0xa06381a17b090b8db5ffef97c6e861baad94a1b0e3210e6309de84c15337811d" validator_host: host: 35.232.235.205 port: 6180 full_node_host: host: 34.135.169.144 port: 6182 stake_amount: 1
-
Create layout YAML file, which defines the node in the validatorSet, for test mode, we can create a genesis blob containing only one node.
$ vi layout.yaml
Add root key, node username, and chain_id in the
layout.yaml
file, for example:--- root_key: "0x5243ca72b0766d9e9cbf2debf6153443b01a1e0e6d086c7ea206eaf6f8043956" users: - <username you created in step 5> chain_id: 5
-
Download AptosFramework Move bytecodes.
Download the Aptos Framework from the release page: https://github.com/aptos-labs/aptos-core/releases/tag/aptos-framework-v0.1.0
$ unzip framework.zip
You should now have a folder called
framework
, which contains move bytecodes with format.mv
. -
Compile genesis blob and waypoint
$ aptos genesis generate-genesis --local-repository-dir ~/$WORKSPACE --output-dir ~/$WORKSPACE
This should create two files in your working directory,
genesis.blob
andwaypoint.txt
-
To re-cap, in your working directory, you should have a list of files:
validator.yaml
validator config filefullnode.yaml
fullnode config filedocker-compose.yaml
docker compose file to run validator and fullnodeprivate-keys.yaml
Private keys for owner account, consensus, networkingvalidator-identity.yaml
Private keys for setting validator identityvalidator-full-node-identity.yaml
Private keys for setting validator full node identity<username>.yaml
Node info for both validator / fullnodelayout.yaml
layout file to define root key, validator user, and chain IDframework
folder which contains all the move bytecode for AptosFramework.waypoint.txt
waypoint for genesis transactiongenesis.blob
genesis binary contains all the info about framework, validatorSet and more.
-
Run docker-compose:
docker-compose up
.
aptos-node
Folders and files
Name | Name | Last commit date | ||
---|---|---|---|---|
parent directory.. | ||||