|
| 1 | +#!/bin/bash |
| 2 | + |
| 3 | +# This guide assumes you already clone the github repository |
| 4 | +# You have to cd to the repository |
| 5 | + |
| 6 | +# Set new server name |
| 7 | +while :; do |
| 8 | + echo -e "\nEnter new server name:" |
| 9 | + read -p "> " new_server_name |
| 10 | + |
| 11 | + if [[ ! "$new_server_name" =~ ^[a-zA-Z0-9-]+$ ]]; then |
| 12 | + echo "Invalid characters used in the server name. Please use only alphanumeric characters and hyphens (-)." |
| 13 | + else |
| 14 | + echo -e "\nSetting new server name to '$new_server_name'..." |
| 15 | + echo "Old server name: $old_server_name" |
| 16 | + sudo hostnamectl set-hostname "$new_server_name" |
| 17 | + sudo sed -i "s/$old_server_name/$new_server_name/g" /etc/hosts |
| 18 | + echo "Please reconnect to the server to see the name change." |
| 19 | + break |
| 20 | + fi |
| 21 | +done |
| 22 | + |
| 23 | +# Enable linger |
| 24 | +sudo loginctl enable-linger user |
| 25 | + |
| 26 | +# Install other dependencies |
| 27 | +sudo apt install -y gcc pkg-config libssl-dev build-essential apt-transport-https ca-certificates curl software-properties-common nvtop |
| 28 | + |
| 29 | +# Install docker |
| 30 | +sudo apt-get update |
| 31 | +sudo apt-get install ca-certificates curl |
| 32 | +sudo install -m 0755 -d /etc/apt/keyrings |
| 33 | +sudo curl -fsSL https://download.docker.com/linux/ubuntu/gpg -o /etc/apt/keyrings/docker.asc |
| 34 | +sudo chmod a+r /etc/apt/keyrings/docker.asc |
| 35 | +echo \ |
| 36 | + "deb [arch=$(dpkg --print-architecture) signed-by=/etc/apt/keyrings/docker.asc] https://download.docker.com/linux/ubuntu \ |
| 37 | + $(. /etc/os-release && echo "$VERSION_CODENAME") stable" | \ |
| 38 | + sudo tee /etc/apt/sources.list.d/docker.list > /dev/null |
| 39 | +sudo apt-get update |
| 40 | +sudo apt-get install docker-ce docker-ce-cli containerd.io docker-buildx-plugin docker-compose-plugin |
| 41 | +sudo groupadd docker |
| 42 | +sudo usermod -aG docker $USER |
| 43 | +newgrp docker |
| 44 | + |
| 45 | +# Install tailscale |
| 46 | +curl -fsSL https://pkgs.tailscale.com/stable/ubuntu/noble.noarmor.gpg | sudo tee /usr/share/keyrings/tailscale-archive-keyring.gpg >/dev/null |
| 47 | +curl -fsSL https://pkgs.tailscale.com/stable/ubuntu/noble.tailscale-keyring.list | sudo tee /etc/apt/sources.list.d/tailscale.list |
| 48 | +sudo apt-get update |
| 49 | +sudo apt-get install tailscale |
| 50 | +sudo tailscale up --ssh --advertise-tags=tag:server && sudo tailscale set --auto-update |
| 51 | + |
| 52 | +# Install CUDA |
| 53 | +sudo add-apt-repository ppa:graphics-drivers/ppa |
| 54 | +sudo apt update |
| 55 | +sudo apt install nvidia-driver-570 |
| 56 | + |
| 57 | +# If see errors |
| 58 | +sudo apt-mark unhold cuda-drivers cuda-toolkit-12-6 nvidia-dkms-565-server nvidia-fabricmanager-565 nvidia-headless-565-server nvidia-utils-565-server |
| 59 | +sudo apt update |
| 60 | +sudo apt install nvidia-driver-570 |
| 61 | +sudo apt autoremove |
| 62 | +sudo apt autoclean |
| 63 | +sudo reboot |
| 64 | +nvidia-smi # To check if the driver is installed correctly |
| 65 | + |
| 66 | +# Setup Docker and CUDA |
| 67 | +curl -fsSL https://nvidia.github.io/libnvidia-container/gpgkey | sudo gpg --dearmor -o /usr/share/keyrings/nvidia-container-toolkit-keyring.gpg |
| 68 | +curl -s -L https://nvidia.github.io/libnvidia-container/stable/deb/nvidia-container-toolkit.list | \ |
| 69 | + sed 's#deb https://#deb [signed-by=/usr/share/keyrings/nvidia-container-toolkit-keyring.gpg] https://#g' | \ |
| 70 | + sudo tee /etc/apt/sources.list.d/nvidia-container-toolkit.list |
| 71 | +sudo apt-get update |
| 72 | +sudo apt-get install -y nvidia-container-toolkit |
| 73 | +sudo nvidia-ctk runtime configure --runtime=docker |
| 74 | +sudo systemctl restart docker |
| 75 | + |
| 76 | +# Install Rust |
| 77 | +curl --proto '=https' --tlsv1.2 -sSf https://sh.rustup.rs | sh |
| 78 | +. "$HOME/.cargo/env" |
| 79 | + |
| 80 | +# Install SP1 |
| 81 | +curl -L https://sp1.succinct.xyz | bash |
| 82 | +source $HOME/.bashrc |
| 83 | +sp1up |
| 84 | + |
| 85 | +# Install cast |
| 86 | +curl -L https://foundry.paradigm.xyz | bash |
| 87 | +source $HOME/.bashrc |
| 88 | +foundryup |
| 89 | + |
| 90 | +# Create directories |
| 91 | +mkdir -p ~/config |
| 92 | +mkdir -p ~/.config/systemd/user |
| 93 | +mkdir -p ~/.keystores |
| 94 | + |
| 95 | +# Create keystore |
| 96 | +cast wallet import proof_aggregation.keystore -k $HOME/.keystores -i |
| 97 | + |
| 98 | +# Create config file interactively |
| 99 | +./infra/aggregation_mode/config_file.sh ./infra/aggregation_mode/config-proof-aggregator.template.yaml |
| 100 | +touch $HOME/config/proof-aggregator.last_aggregated_block.json |
| 101 | +read -p "Enter a number (last_aggregated_block): " num && echo "{\"last_aggregated_block\":$num}" > $HOME/config/proof-aggregator.last_aggregated_block.json |
| 102 | + |
| 103 | +# Build the proof_aggregator |
| 104 | +make install_aggregation_mode |
| 105 | + |
| 106 | +# Setup systemd service |
| 107 | +cp ./infra/aggregation_mode/aggregation_mode.service $HOME/.config/systemd/user/aggregation_mode.service |
| 108 | +cp ./infra/aggregation_mode/aggregation_mode.timer $HOME/.config/systemd/user/aggregation_mode.timer |
| 109 | + |
| 110 | +#sudo systemctl enable aggregation_mode.service |
| 111 | +systemctl --user enable aggregation_mode.timer |
| 112 | +systemctl --user start aggregation_mode.timer |
| 113 | + |
| 114 | +# Run the proof_aggregator manually if you want |
| 115 | +systemctl --user start aggregation_mode.service |
| 116 | + |
| 117 | +# Check timer status |
| 118 | +systemctl --user status aggregation_mode.timer |
| 119 | + |
| 120 | +# Check logs |
| 121 | +journalctl -xfeu aggregation_mode.service --user -n10 |
0 commit comments