High-performance external mining service for Quantus Network with support for CPU, GPU, and hybrid CPU+GPU mining.
# CPU-only build (default)
cargo build -p miner-cli --release
# With GPU support (recommended)
cargo build -p miner-cli --release
The binary will be available at target/release/quantus-miner.
# CPU-only mining (default: auto-detected CPU cores)
./target/release/quantus-miner serve --cpu-workers 4
# GPU-only mining
./target/release/quantus-miner serve --gpu-devices 1
# Hybrid CPU+GPU mining
./target/release/quantus-miner serve --cpu-workers 4 --gpu-devices 1
# Custom port and metrics
./target/release/quantus-miner serve --cpu-workers 2 --port 8000 --metrics-port 9900
| Argument | Environment Variable | Description | Default |
|---|---|---|---|
--node-addr <ADDR> | MINER_NODE_ADDR | Node address to connect to | 127.0.0.1:9833 |
--cpu-workers <N> | MINER_CPU_WORKERS | Number of CPU worker threads | Auto-detect |
--gpu-devices <N> | MINER_GPU_DEVICES | Number of GPU devices | Auto-detect |
--gpu-batch-size <N> | MINER_GPU_BATCH_SIZE | GPU batch size in nonces | 1000000 |
--cpu-batch-size <N> | MINER_CPU_BATCH_SIZE | CPU batch size in hashes | 10000 |
--gpu-throttle-ms <MS> | MINER_GPU_THROTTLE_MS | Sleep duration (ms) between GPU batches | 0 |
--metrics-port <PORT> | MINER_METRICS_PORT | Prometheus metrics port | 9900 |
GPU support uses WGPU for cross-platform acceleration:
Build with GPU support:
cargo build -p miner-cli --release
Platform requirements:
nvidia-driver, mesa-vulkan-drivers)sudo powermetrics --samplers gpu_power -i 1000nvidia-smi (NVIDIA) or radeontop (AMD)# CPU mining with 8 workers
./target/release/quantus-miner serve --cpu-workers 8
# Pure GPU mining
./target/release/quantus-miner serve --gpu-devices 1
# GPU mining with throttle (reduce GPU utilization)
./target/release/quantus-miner serve --gpu-devices 1 --gpu-throttle-ms 50
# Hybrid mining: 4 CPU + 1 GPU workers
./target/release/quantus-miner serve --cpu-workers 4 --gpu-devices 1
# With verbose logging
RUST_LOG=debug ./target/release/quantus-miner serve --cpu-workers 2 --gpu-devices 1
# Production setup with metrics
./target/release/quantus-miner serve \
--cpu-workers 6 \
--gpu-devices 1 \
--port 9833 \
--metrics-port 9900
The miner uses a QUIC-based protocol for communication with the node:
NewJob (from node) and JobResult (from miner)For full protocol specification, see EXTERNAL_MINER_PROTOCOL.md.
# Quick start
docker pull ghcr.io/quantus-network/quantus-miner:latest
docker run -d -p 9833:9833 -p 9900:9900 \
ghcr.io/quantus-network/quantus-miner:latest \
--cpu-workers 4 --metrics-port 9900
# Build from source
docker build -t quantus-miner .
docker run -d -p 9833:9833 quantus-miner serve --cpu-workers 4
# Benchmark CPU performance
./target/release/quantus-miner benchmark --cpu-workers 8 --duration 30
# Benchmark GPU performance
./target/release/quantus-miner benchmark --gpu-devices 1 --duration 30
# Benchmark hybrid performance
./target/release/quantus-miner benchmark --cpu-workers 4 --gpu-devices 1 --duration 30
176 activities