Run a Hubble on GCP
Intro
This is a step-by-step guide to setting up Hubble on GCP. It usually takes less than 30 minutes to complete the whole process.
Requirements
Costs
- GCP setup recommended in this tutorial may cost up to $70/month
- Alchemy usage should stay within the free tier
Create GCP VM
Open Google Cloud Shell and execute the following commands:
data:image/s3,"s3://crabby-images/1c2bc/1c2bcffd624d92cdb7702298628a48b2fe6b2802" alt=""
Click on Google Cloud Shell Icon
Execute the below commands in the cloud shell:
mkdir farcaster-hub
cd farcaster-hub
nano main.tf
Now paste the content of below into your main.tf
Replace "$YOUR_PROJECT_ID" with your personal ID.
data:image/s3,"s3://crabby-images/ea5a5/ea5a554d924ce806ab8b9a497b9f1d988e0a8c25" alt=""
This is the configuration of your GCP virtual machine that will be created.
provider "google" {
project = "$YOUR_PROJECT_ID"
region = "us-central1"
}
resource "google_compute_instance" "farcaster-hub-vm" {
name = "farcaster-hub-vm"
machine_type = "e2-standard-4" # 4 vCPUs, 16 GB memory
zone = "us-central1-a" # Specify the zone here
boot_disk {
initialize_params {
image = "ubuntu-2004-focal-v20231213" # Ubuntu 20.04 LTS image URL
size = 300 # 300 GB disk size
}
}
network_interface {
network = "default"
access_config {
// This will assign a public IP address to the instance
}
}
tags = ["allow-farcaster-p2p-ports"] # For firewall rule
metadata = {
# You can add any additional metadata here if needed
}
}
resource "google_compute_firewall" "farcaster-p2p-ports" {
name = "farcaster-p2p-ports"
network = "default"
# allow incoming traffic for ports 2282-2285
allow {
protocol = "tcp"
ports = ["2282-2285"]
}
source_ranges = ["0.0.0.0/0"]
}
Execute this command:
terraform init # to initialize terraform in your farcaster-hub folder
Execute this command:
terraform plan # this will simulate your terraform configuration & check if it is correct
Example output:
data:image/s3,"s3://crabby-images/b8ece/b8ece0e40f5705d526840060118740ea7030a6b7" alt=""
Example output of terraform plan
Enable Compute Engine API
data:image/s3,"s3://crabby-images/c9770/c97701cc269b0ac8ff2672de533d3b3f64750e14" alt=""
Now execute this command:
terraform apply
data:image/s3,"s3://crabby-images/17b27/17b2771ecefc165aeae31353084a452ede8f7ba2" alt=""
Example output of Terraform apply
It will take a few minutes before the VM is created. Time to enjoy your ☕
data:image/s3,"s3://crabby-images/4a466/4a4665555b3b142da5a43f17f55eced0c2ab3d35" alt=""
Now you should be able to connect to your VM by clicking on the SSH button.
Now Install Docker as described here https://docs.docker.com/engine/install/ubuntu/
Now follow the steps as described on Install page
Your Hubble is up and running when you see below :white_check_mark:
data:image/s3,"s3://crabby-images/30d77/30d777251dd20052d41ec2bed036761a6e7088d7" alt=""