# Deploy Using Ansible
In this tutorial, you will learn how to deploy Zarb into your Virtual Private Server (VPS) without compiling Zarb and using docker.
# 🎮 What Is Ansible?
Ansible is all about automation, it requires instructions to accomplish each job. With everything written down in simple script form, it's easy to do version control.
In Ansible, there are two computers: the control node and managed nodes. The control node is your computer that runs Ansible. A managed node is any device being managed by the control node.
Ansible on Windows
Unfortunately Windows is not supported (opens new window) for the control node. If you want to run an Ansible controller on Windows, use WSL.
# Why Ansible?
Deploying Zarb is not a one time task. You may update the node time to time or change the configuration or even restart the node. Ansible helps you to automate the deployment process. If you are going to run a full node in Zarb, we recommend to use Ansible or Terraform for deploying Zarb.
Using a linux cloud server is the best way to run a validator in Zarb network. You may get a virtual private server from providers like Amazon, Microsoft, Linde, Alibaba, ArvanCloud, etc.
# Recommended Hardware
- Processor: Two dedicated core of CPU
- Memory: Two gigabyte of RAM
- Storage: 10 Gigabytes of free space disk
- Network: A broadband Internet connection
# 🛡️ Securing the server
The first step is securing your server. You may read this guid line (opens new window) to learn how to setup your sever more secure.
# Step by Step
Make sure you have installed Ansible (opens new window) in your local machine and you have access to your server through SSH (opens new window).
All the commands in this tutorial will be run in your local machine (probably your laptop) and you don't need to ssh into your server.
Also if you have installed firewall in your server machine, make sure these port are open:
- 8421 for p2p network
- 8080 for gRPC gateway
- 9090 for gRPC
First you need to clone this repository:
git clone https://github.com/zarbchain/zarb-deploy-ansible-example cd zarb-deploy-ansible-example
inventory.yml and update
ansible_host with your server remote ip address. something like:
ansible all -m gather_facts to make sure ansible works fine.
Now, you need to generate two keys in your local machine. One for the validator and another for collecting the rewards. To generate new keys you needs to execute the Zarb in your local machine. You can either download (opens new window) the latest precompiled binaries or compile it from the source code.
zarb key generate -p ~/zarb/keystore/validator_key.json zarb key generate -p ~/zarb/keystore/mintbase_key.json
This command will generate new keys and save them at:
Make sure you write down the Mnemonics of your keys. You can recover your keys from Mnemonics, if you lose them.
You should know that you are responsible for the safety of your key.
To store and send validator private key to server, we use Ansible vault (opens new window). Ansible Vault encrypts variables so you can protect sensitive content such as secret keys.
Before creating Ansible Vault, you need to know the private key for the validator. Using
zarb inspect command you can see the private key.
zarb key inspect -e ~/zarb/keystore/validator_key.json
Copy the private key. You will need to paste in inside Ansible Vault in the next step.
Now let's create a vault and add the validator private key inside the vault.
ansible-vault create --vault-id vault@prompt tasks/vault.yml
Set a strong password for the Vault.
It opens up an editor. Once you're inside, treat this like a normal variable file: add ---, then a new variable:
--- vault_validator_key: <validator_private_key>
The colon must be followed by a space.
Ansible will encrypt the key and save inside
task/vault.yml. You can open the
see the content. It should be encrypted.
One more step, open the config file and update
MintbaseAddress. This can be different from the
validator address. You can also change other configs like
Address in Zarb starts with
# Installing Ansible Plugins
Before deploying Zarb, you have to install two plugins for Ansible.
First install the
geerlingguy.docker plugin. This plugin will install docker for the server
ansible-galaxy install geerlingguy.docker
And then install the
geerlingguy.ntp plugin. This plugin will synchronizing your server Time using
Network Time Protocol (NTP).
ansible-galaxy install geerlingguy.ntp
# Deploy Zarb
Now you can deploy Zarb by running deploy playbook:
ansible-playbook --ask-become-pass --vault-id tasks/vault@prompt tasks/deploy.yml
Now you can check "http://<ip_address>:8080" to see if your node works fine and it's syncing with the network.
# Update Zarb
If you change the configuration or if you want to update the node version, run the deploy playbook again. This will update the docker image and restart the node.
Welcome to Zarb network 🤝