Skip to content

aashaka/rainblock-deploy

Repository files navigation

Dependencies

docker shyaml: pip install shyaml

Demo

  1. Edit config.yaml
    • Replace remote_user to user of a machine you are able to ssh into with your current username
    • Replace IPs with IPs of the machine you are able to ssh into
  2. Run ./deploy.sh 1 1 1
  3. View logs in logs/

Experiments

Config

Setup configs in config.yaml. See config.yaml.example file for how to set it up. Docker username and password is required to push to a docker repo and pull from a private docker repo.

Creating Docker images

./bootstrap/create_fresh_images.sh generates following images and pushes them to dockerhub:

  1. rainblock/rainblock:mainStore - storage node image
  2. rainblock/rainblock:testVerifStore - test verifier which simply interacts with storage nodes
  3. rainblock/rainblock:testCliStore - test client which simply interacts with storage nodes

Deploying Docker containers

  • ./deploy.sh storage_node.sh num_storage num_evm num_client will deploy entire system. It is made up of following commands explained below:

  • Run deploy_storage.sh num_storage_containers to get storage nodes started on storage_nodes IPs specified in config.yaml.

    • The storage container ports are assumed to be 50051. They are mapped to ports starting from 4000 in each machine the containers are deployed in.
    • Number of storage containers will be evenly distributed between storage IPs provided in config.yaml
    • It is assumed that the containers will run on Chameleon Cloud. Change USERNAME field from cc to match your username on remote host
    • All storage IP:port will be written to storage_ips.txt in a comma newline separated format after deploy_storage.sh
  • Run deploy_evm.sh num_evm_containers to get evm nodes started on evm_nodes IPs specified in config.yaml. Right now, evm is test_verif_store instance.

    • The storage IP and port that evm should connect to are sent as the environment variable $SNODES. SNODES is the content of storage_ips.txt.
    • The actual EVM container will keep ports open for clients to connect to. This port is assumed to be 50052. They are mapped to ports starting from 6000 in each machine the containers are deployed in.
    • Number of evm containers will be evenly distributed between evm IPs provided in config.yaml
    • It is assumed that the containers will run on Chameleon Cloud. Change USERNAME field from cc to match your username on remote host
    • EVM IP:port will be written to evm_ips.txt in a comma newline separated format after deploy_evm.sh
  • Run deploy_client.sh num_client_containers to get client nodes started on client_nodes IPs specified in config.yaml. Right now, client is test_client_store instance.

    • The storage IP and port & EVM IP and port that client should connect to are sent as the environment variable $SNODES and $ENODES. SNODES and ENODES are the content of storage_ips.txt and evm_ips.txt
    • Number of client containers will be evenly distributed between client IPs provided in config.yaml
    • It is assumed that the containers will run on Chameleon Cloud. Change USERNAME field from cc to match your username on remote host

Note

  • For dockerizing, testVerifier.ts and testClient.ts in rainblock-storage needs extra environment variable handling to get storage nodes IP:port. We use a separate branch dockertest on rainblock-storage for this. We create docker containers from this branch.
  • Downloading a zip file directly from github/gitlab repo and making docker image based on it will fail. This is because it will not have a .git folder, which is required for gitmodules to initialize. Instead, clone the repo, zip it and send it over to docker image.

About

Docker deployment of rainblock components

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published