Skip to content

Latest commit

 

History

History
114 lines (81 loc) · 5.86 KB

README.md

File metadata and controls

114 lines (81 loc) · 5.86 KB

BitMind Validator Setup

This guide explains how to set up and run the BitMind Validator Docker container on your machine.

Step 1: Copy and Modify Environment Variables

Start by copying the provided .env.example file to .env and modify it according to your network and wallet configuration.

cp .env.example .env

Then, modify the .env file to include your network details, API keys, and wallet information. Here’s an example of what your .env file might look like:

# Network Configuration:
NETUID=34                                      # Network User ID options: 34, 168
SUBTENSOR_NETWORK=finney                       # Networks: finney, test, local
SUBTENSOR_CHAIN_ENDPOINT=wss://entrypoint-finney.opentensor.ai:443
                                                # Endpoints:
                                                # - wss://entrypoint-finney.opentensor.ai:443
                                                # - wss://test.finney.opentensor.ai:443/

# Validator Port Setting:
VALIDATOR_AXON_PORT=8092

# API Keys:
WANDB_API_KEY=your_wandb_api_key_here
HUGGING_FACE_TOKEN=your_hugging_face_token_here

# Wallet names
WALLET_NAME=default
WALLET_HOTKEY=default

# Wallets
COLDKEY_ADDRESS=
HOTKEY_MNEMONIC=

Explanation of Key Variables:

  • NETUID: Subnet uid, options are 34 (for finney) and 168 (for test).
  • SUBTENSOR_NETWORK: Network name, options include finney (mainnet), test, or local.
  • SUBTENSOR_CHAIN_ENDPOINT: The WebSocket endpoint to connect to.
  • VALIDATOR_AXON_PORT: The port used by the validator service.
  • WANDB_API_KEY: Your Weights & Biases API key for experiment tracking.
  • HUGGING_FACE_TOKEN: Your Hugging Face token for accessing models.
  • COLDKEY_ADDRESS: Your wallet coldkey address.
  • HOTKEY_MNEMONIC: The mnemonic phrase for regenerating your wallet hotkey.

Step 2: Host Machine Prerequisites

Before running the Docker container, ensure that your host machine has the following software installed:

  1. CUDA Toolkit: This is required to run CUDA applications on your GPU.
  2. NVIDIA Drivers: Ensure the correct NVIDIA drivers are installed on your machine to support GPU acceleration.
  3. cuDNN: NVIDIA's CUDA Deep Neural Network library for accelerating deep learning workloads.
  4. NVIDIA Container Toolkit: This toolkit is required to run Docker containers with GPU support.

Installing NVIDIA Drivers and Toolkit

Follow the official guides to install the necessary drivers and tools for GPU support:

Step 3: Modify Dockerfile to Fit Your Machine Setup

The base image in the Dockerfile can be changed depending on your host machine’s configuration. When choosing the base image, make sure to use one with the cudnn-devel tag for proper cuDNN support and development headers, and ensure it is based on Ubuntu for compatibility. You can find appropriate CUDA base images from the NVIDIA NGC Container Catalog.

Example Modification:

If your machine has a specific CUDA version installed, you can change the base image in the Dockerfile by modifying the BASE_IMAGE build argument.

ARG BASE_IMAGE=nvcr.io/nvidia/cuda:11.6.1-cudnn8-devel-ubuntu20.04

In this example, the base image is set to nvcr.io/nvidia/cuda:11.6.1-cudnn8-devel-ubuntu20.04. You can change this to match your CUDA version.

Step 4: Build and Run the Docker Container

Once you have your .env file configured and prerequisites installed, you can build and run the container:

docker compose up -d --build

What Happens After Running docker compose up -d --build:

  • Build and Image Creation: The first time you run docker compose, it builds a new Docker image using the Dockerfile.
  • Entrypoint Script Execution: During the container startup, the entrypoint.sh script regenerates keys (coldkey and hotkey) inside the container using the environment variables provided in your .env file.
  • Volume Mounting: Two volumes are mounted to your local machine to ensure persistence of data between container restarts:
    • ./container-data/.bittensor is mounted to /root/.bittensor inside the container. This stores keys and other configuration files.
    • ./container-data/.cache/huggingface is mounted to /root/.cache/huggingface. This stores Hugging Face cache files for persisted access to models.
  • Conda Environment Activation: The bitmind Conda environment is activated to load all necessary dependencies for the validator service.
  • Key Regeneration: The coldkeypub and hotkey are regenerated using btcli based on the values in the .env file.
  • Weights & Biases Login: The container logs in to Weights & Biases using the provided API key. If the login fails, the process halts.
  • Hugging Face Login: The script logs in to Hugging Face with the provided token. If login fails, the process stops.
  • Model Verification: A Python script (verify_models.py) checks your access to synthetic image generation models. If access is not available, the process stops.
  • Validator Execution: The validator is launched using neurons/validator.py with the network and wallet details you provided, along with the specified axon port.

This ensures that your validator is correctly set up and all required services are running smoothly.

Step 5: Validate the Setup

To ensure everything is running properly, you can check the logs:

docker logs bitmind_validator --follow

If everything is set up correctly, you should see your validator logs.