diff --git a/developer-docs-site/docs/tutorials/validator-node/using-aws.md b/developer-docs-site/docs/tutorials/validator-node/using-aws.md index 8e1587e7778b7..0e20b25376afc 100644 --- a/developer-docs-site/docs/tutorials/validator-node/using-aws.md +++ b/developer-docs-site/docs/tutorials/validator-node/using-aws.md @@ -108,7 +108,7 @@ This will download all the terraform dependencies for you, in the `.terraform` f This will create three files: `private-keys.yaml`, `validator-identity.yaml`, `validator-full-node-identity.yaml` for you. **IMPORTANT**: Backup your key files somewhere safe. These key files are important for you to establish ownership of your node, and you will use this information to claim your rewards later if eligible. Never share those keys with anyone else. -11. Configure validator information. +11. Configure validator information. This is all the info you need to register on our community website later. ``` aptos genesis set-validator-configuration --keys-dir ~/$WORKSPACE --local-repository-dir ~/$WORKSPACE --username --validator-host $VALIDATOR_ADDRESS:6180 --full-node-host $FULLNODE_ADDRESS:6182 diff --git a/developer-docs-site/docs/tutorials/validator-node/using-azure.md b/developer-docs-site/docs/tutorials/validator-node/using-azure.md new file mode 100644 index 0000000000000..1163497cd2eaa --- /dev/null +++ b/developer-docs-site/docs/tutorials/validator-node/using-azure.md @@ -0,0 +1,204 @@ +--- +title: "Run Validator Node Using Azure" +slug: "run-validator-node-using-azure" +sidebar_position: 11 +--- + +## Run on AWS +This guide assumes you already have Azure account setup. + +Install pre-requisites if needed: + + * Aptos CLI: https://github.com/aptos-labs/aptos-core/blob/main/crates/aptos/README.md + * Terraform 1.1.7: https://www.terraform.io/downloads.html + * Kubernetes CLI: https://kubernetes.io/docs/tasks/tools/ + * Azure CLI: https://docs.microsoft.com/en-us/cli/azure/install-azure-cli + +1. Create a working directory for your configuration. + + * Choose a workspace name e.g. `testnet`. Note: This defines Terraform workspace name, which in turn is used to form resource names. + ``` + export WORKSPACE=testnet + ``` + + * Create a directory for the workspace + ``` + mkdir -p ~/$WORKSPACE + ``` + +2. Create a blob storage container for storing the Terraform state on Azure, you can do this on Azure UI or by the command: + + ``` + az group create -l -n aptos-$WORKSPACE + az storage account create -n -g aptos-$WORKSPACE -l --sku Standard_LRS + az storage container create -n --account-name --resource-group aptos-$WORKSPACE + ``` + +3. Create Terraform file called `main.tf` in your working directory: + ``` + cd ~/$WORKSPACE + vi main.tf + ``` + +4. Modify `main.tf` file to configure Terraform, and create fullnode from Terraform module. Example content for `main.tf`: + ``` + terraform { + required_version = "~> 1.1.0" + backend "azurerm" { + resource_group_name = + storage_account_name = + container_name = + key = "state/validator" + } + } + + + module "aptos-node" { + # download Terraform module from aptos-labs/aptos-core repo + source = "github.com/aptos-labs/aptos-core.git//terraform/aptos-node/azure?ref=main" + region = # Specify the region + era = 1 # bump era number to wipe the chain + chain_id = 23 + image_tag = "testnet" # Specify the docker image tag to use + validator_name = "" + } + ``` + + For the full customization options, see the variables file [here](https://github.com/aptos-labs/aptos-core/blob/main/terraform/aptos-node/azure/variables.tf), and the [helm values](https://github.com/aptos-labs/aptos-core/blob/main/terraform/helm/aptos-node/values.yaml). + +5. Initialize Terraform in the same directory of your `main.tf` file + ``` + terraform init + ``` +This will download all the terraform dependencies for you, in the `.terraform` folder in your current working directory. + +6. Create a new Terraform workspace to isolate your environments: + ``` + terraform workspace new $WORKSPACE + # This command will list all workspaces + terraform workspace list + ``` + +7. Apply the configuration. + ``` + terraform apply + ``` + This might take a while to finish (~20 minutes), Terraform will create all the resources on your cloud account. + +8. Once terraform apply finishes, you can check if those resources are created: + + - `az aks get-credentials --resource-group aptos-$WORKSPACE --name aptos-$WORKSPACE` to configure access for your k8s cluster. + - `kubectl get pods` this should have haproxy, validator and fullnode. with validator and fullnode pod `pending` (require further action in later steps) + - `kubectl get svc` this should have `validator-lb` and `fullnode-lb`, with an external-IP you can share later for connectivity. + +9. Get your node IP info: + + ``` + export VALIDATOR_ADDRESS="$(kubectl get svc ${WORKSPACE}-aptos-node-validator-lb --output jsonpath='{.status.loadBalancer.ingress[0].hostname}')" + + export FULLNODE_ADDRESS="$(kubectl get svc ${WORKSPACE}-aptos-node-fullnode-lb --output jsonpath='{.status.loadBalancer.ingress[0].hostname}')" + ``` + +10. 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. **IMPORTANT**: Backup your key files somewhere safe. These key files are important for you to establish ownership of your node, and you will use this information to claim your rewards later if eligible. Never share those keys with anyone else. + +11. Configure validator information. This is all the info you need to register on our community website later. + + ``` + aptos genesis set-validator-configuration --keys-dir ~/$WORKSPACE --local-repository-dir ~/$WORKSPACE --username --validator-host $VALIDATOR_ADDRESS:6180 --full-node-host $FULLNODE_ADDRESS:6182 + + ``` + + This will create a YAML file in your working directory with your username, e.g. `aptosbot.yaml`, it should looks like below: + + ``` + --- + account_address: 7410973313fd0b5c69560fd8cd9c4aaeef873f869d292d1bb94b1872e737d64f + consensus_key: "0x4e6323a4692866d54316f3b08493f161746fda4daaacb6f0a04ec36b6160fdce" + account_key: "0x83f090aee4525052f3b504805c2a0b1d37553d611129289ede2fc9ca5f6aed3c" + network_key: "0xa06381a17b090b8db5ffef97c6e861baad94a1b0e3210e6309de84c15337811d" + validator_host: + host: 30247cc34f270cb8.elb.us-west-2.amazonaws.com + port: 6180 + full_node_host: + host: abc5b9734d4cc418.elb.us-west-2.amazonaws.com + port: 6182 + stake_amount: 1 + ``` + +12. 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: + - + chain_id: 23 + ``` + +13. Download AptosFramework Move bytecodes into a folder named `framework`. + + Download the Aptos Framework from the release page: https://github.com/aptos-labs/aptos-core/releases/tag/aptos-framework-v0.1.0 + + ``` + wget https://github.com/aptos-labs/aptos-core/releases/download/aptos-framework-v0.1.0/framework.zip + + unzip framework.zip + ``` + + You should now have a folder called `framework`, which contains move bytecodes with format `.mv`. + +14. 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` and `waypoint.txt` + +15. To recap, in your working directory, you should have a list of files: + - `main.tf` the Terraform files to install aptos-node module. + - `private-keys.yaml` Private keys for owner account, consensus, networking + - `validator-identity.yaml` Private keys for setting validator identity + - `validator-full-node-identity.yaml` Private keys for setting validator full node identity + - `.yaml` Node info for both validator / fullnode + - `layout.yaml` layout file to define root key, validator user, and chain ID + - `framework` folder which contains all the move bytecode for AptosFramework. + - `waypoint.txt` waypoint for genesis transaction + - `genesis.blob` genesis binary contains all the info about framework, validatorSet and more. + +16. Insert `genesis.blob`, `waypoint.txt` and the identity files as secret into k8s cluster. + + ``` + kubectl create secret generic ${WORKSPACE}-aptos-node-genesis-e1 \ + --from-file=genesis.blob=genesis.blob \ + --from-file=waypoint.txt=waypoint.txt \ + --from-file=validator-identity.yaml=validator-identity.yaml \ + --from-file=validator-full-node-identity.yaml=validator-full-node-identity.yaml + ``` + + If you changed the era number, make sure it matches when creating the secret. + +17. Check all pods running. + + ``` + kubectl get pods + + NAME READY STATUS RESTARTS AGE + node1-aptos-node-fullnode-e9-0 1/1 Running 0 4h31m + node1-aptos-node-haproxy-7cc4c5f74c-l4l6n 1/1 Running 0 4h40m + node1-aptos-node-validator-0 1/1 Running 0 4h30m + ``` + +Now you have completed setting up your node in test mode. You can continue to our [community](https://community.aptoslabs.com/) website for registration. \ No newline at end of file diff --git a/developer-docs-site/docs/tutorials/validator-node/using-docker.md b/developer-docs-site/docs/tutorials/validator-node/using-docker.md index dc61356cbc027..593f6da250040 100644 --- a/developer-docs-site/docs/tutorials/validator-node/using-docker.md +++ b/developer-docs-site/docs/tutorials/validator-node/using-docker.md @@ -34,7 +34,7 @@ sidebar_position: 12 This will create three files: `private-keys.yaml`, `validator-identity.yaml`, `validator-full-node-identity.yaml` for you. **IMPORTANT**: Backup your key files somewhere safe. These key files are important for you to establish ownership of your node, and you will use this information to claim your rewards later if eligible. Never share those keys with anyone else. -5. 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. +5. 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. This is all the info you need to register on our community website later. ``` aptos genesis set-validator-configuration \ diff --git a/developer-docs-site/docs/tutorials/validator-node/using-gcp.md b/developer-docs-site/docs/tutorials/validator-node/using-gcp.md index 4de58ecaccfcf..c24625bb77f32 100644 --- a/developer-docs-site/docs/tutorials/validator-node/using-gcp.md +++ b/developer-docs-site/docs/tutorials/validator-node/using-gcp.md @@ -110,7 +110,7 @@ This will download all the Terraform dependencies for you, in the `.terraform` f This will create three files: `private-keys.yaml`, `validator-identity.yaml`, `validator-full-node-identity.yaml` for you. **IMPORTANT**: Backup your key files somewhere safe. These key files are important for you to establish ownership of your node, and you will use this information to claim your rewards later if eligible. Never share those keys with anyone else. -11. Configure validator information. +11. Configure validator information. This is all the info you need to register on our community website later. ``` aptos genesis set-validator-configuration --keys-dir ~/$WORKSPACE --local-repository-dir ~/$WORKSPACE --username --validator-host $VALIDATOR_ADDRESS:6180 --full-node-host $FULLNODE_ADDRESS:6182 diff --git a/developer-docs-site/docs/tutorials/validator-node/using-source-code.md b/developer-docs-site/docs/tutorials/validator-node/using-source-code.md index dc80b01ba22b7..b323663ea6ad4 100644 --- a/developer-docs-site/docs/tutorials/validator-node/using-source-code.md +++ b/developer-docs-site/docs/tutorials/validator-node/using-source-code.md @@ -52,7 +52,7 @@ With your development environment ready, now you can start to setup your Validat This will create three files: `private-keys.yaml`, `validator-identity.yaml`, `validator-full-node-identity.yaml` for you. **IMPORTANT**: Backup your key files somewhere safe. These key files are important for you to establish ownership of your node, and you will use this information to claim your rewards later if eligible. Never share those keys with anyone else. -8. 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. +8. 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. This is all the info you need to register on our community website later. ``` cargo run -p aptos -- genesis set-validator-configuration \