Manager for Autonomi nodes
Project description
Weave Node Manager
Overview
Weave Node Manager (wnm) is a Python application designed to manage Autonomi nodes on Linux and macOS systems.
Platforms:
- Linux: systemd or antctl for process management, UFW for firewall
- macOS: launchd for process management (native support) or antctl
- Python 3.12.3+ required
Features
- Automatic node lifecycle management (create, start, stop, upgrade, remove)
- Resource-based decision engine (CPU, memory, disk, I/O, load average thresholds)
- Platform-specific process management (systemd on Linux, launchd on macOS)
- Per-node binary copies for independent upgrades
- SQLite database for configuration and state tracking
- Support for configuration via environment variables, config files, or command-line parameters
Warning - Alpha Software
This code is Alpha. On Linux, it can migrate from an existing anm installation. On macOS, it provides native development and testing support using launchd.
Installation
macOS (Development & Testing)
macOS support uses launchd for process management and is ideal for development and testing.
1. Install antup (Autonomi binary manager)
curl -sSL https://raw.githubusercontent.com/maidsafe/antup/main/install.sh | bash
2. Download antnode binary
~/.local/bin/antup node
3. Activate a pyenv environment
pyenv shell 3.14.0
3. Install WNM from PyPI
pip3 install wnm
4. Or install from source
git clone https://github.com/iweave/weave-node-manager.git
cd weave-node-manager
pip3 install -e .
5. Initialize and configure
# Initialize with your rewards address
wnm --init --rewards_address 0xYourEthereumAddress
# Run in dry-run mode to test
wnm --dry_run
# Or run normally to start managing nodes
wnm
6. Optional: Add to cron for automatic management
# Add to crontab (runs every minute)
crontab -e
# Add these lines:
PATH=/usr/local/bin:/usr/bin:/bin:/usr/sbin:/sbin
*/1 * * * * ~/.pyenv/versions/3.14.0/bin/wnm >> ~/Library/Logs/autonomi/wnm-cron.log 2>&1
macOS Notes:
- Uses
~/Library/Application Support/autonomi/node/for data - Uses
~/Library/Logs/autonomi/for logs - Nodes managed via launchd (
~/Library/LaunchAgents/) - No root/sudo access required
Linux (User-Level, Recommended)
Non-root installation using systemd for process management.
1. Install antup (Autonomi binary manager)
curl -sSL https://raw.githubusercontent.com/maidsafe/antup/main/install.sh | bash
2. Download antnode binary
~/.local/bin/antup node
3. Activate a Python virtual environment
python3 -m venv .venv
. ~/.venv/bin/activate
3. Install WNM from PyPI
~/.venv/bin/pip3 install wnm
4. Or install from source
git clone https://github.com/iweave/weave-node-manager.git
cd weave-node-manager
~/.venv/bin/pip3 install -e .
5. Initialize and configure
# Initialize with your rewards address
wnm --init --rewards_address 0xYourEthereumAddress
# Run in dry-run mode to test
wnm --dry_run
# Or run normally
wnm
6. Optional: Add to cron
crontab -e
# Add this line:
export PATH=/usr/local/bin:/usr/sbin:/usr/bin:/bin
*/1 * * * * ~/.venv/bin/wnm >> ~/.local/share/autonomi/logs/wnm-cron.log 2>&1
Linux User-Level Notes:
- Uses
~/.local/share/autonomi/node/for data - Uses
~/.local/share/autonomi/logs/for logs - Nodes run as background processes (setsid)
- No root/sudo required
Configuration
Configuration follows a multi-layer priority system (highest to lowest):
- Command-line arguments:
wnm --cpu_less_than 70 --node_cap 50 - Environment variables: Set in
.envfile or shell environment - Config files:
~/.local/share/wnm/config,~/wnm/config, or-c/--config - Database-stored config: Persisted in
colony.dbafter initialization - Default values: Built-in defaults
Key Configuration Parameters
Resource thresholds control when nodes are added or removed:
--cpu_less_than/--cpu_remove: CPU percentage thresholds (default: 70% / 80%)--mem_less_than/--mem_remove: Memory percentage thresholds (default: 70% / 80%)--hd_less_than/--hd_remove: Disk usage percentage thresholds (default: 70% / 80%)--desired_load_average/--max_load_average_allowed: Load average thresholds--node_cap: Maximum number of nodes (default: 50)--rewards_address: Wallet address(es) for node rewards (required) - see Wallet Configuration below--node_storage: Root directory for node data (auto-detected per platform)
Wallet Configuration
The --rewards_address parameter supports multiple formats for flexible reward distribution:
Single Wallet
Use a single Ethereum address or named wallet:
# Ethereum address
wnm --init --rewards_address 0xYourEthereumAddress
# Named wallet: "donate" (uses your custom donate_address or the community foucet if not deefined)
wnm --init --rewards_address donate
# Named wallet: "faucet" (always uses the autonomi community faucet address)
wnm --init --rewards_address faucet
Weighted Distribution
Distribute rewards across multiple wallets using weighted random selection:
# Format: wallet1:weight1,wallet2:weight2,...
wnm --init --rewards_address "0xYourAddress:100,faucet:1,donate:10"
In this example:
- Your address receives ~90% of nodes (100 out of 111 weight)
- Faucet receives ~1% of nodes (1 out of 111 weight)
- Donate address receives ~9% of nodes (10 out of 111 weight)
Key Features:
- Random per node: Each new node randomly selects a wallet based on weights
- Named wallets: Use
faucet(project faucet) ordonate(your custom donation address) - Case-insensitive:
faucet,FAUCET, andFaucetall work - Mix addresses and names: Combine Ethereum addresses with named wallets
- Changeable: Update
--rewards_addressanytime to change distribution for new nodes
Examples:
# 50/50 split between your address and faucet
wnm --rewards_address "0xYourAddress:1,faucet:1"
# Your address only
wnm --rewards_address 0xYourAddress
# Mostly yours, small donation to faucet
wnm --rewards_address "0xYourAddress:99,faucet:1"
# Multiple addresses with custom weights
wnm --rewards_address "0xAddress1:100,0xAddress2:50,faucet:10"
anm Migration (Linux Only)
Upon finding an existing anm installation, wnm will:
- Disable anm by removing
/etc/cron.d/anm - Import configuration from
/var/antctl/config - Discover and import existing nodes from systemd
- Take over management of the cluster
Use wnm --init --migrate_anm to trigger migration.
Usage
Run Once
# macOS or Linux
wnm
# With dry-run (no actual changes)
wnm --dry_run
# Initialize first time
wnm --init --rewards_address 0xYourEthereumAddress
Run via Cron (Recommended)
WNM is designed to run every minute via cron. By default it performs one operation per cycle, but can be configured for concurrent operations on powerful machines:
macOS:
crontab -e
# Add: */1 * * * * /Users/dawn/.pyenv/versions/3.14.0/bin/wnm>> ~/Library/Logs/autonomi/wnm-cron.log 2>&1
Linux (user):
crontab -e
# Add: */1 * * * * ~/.venv/bin/wnm >> ~/.local/share/autonomi/logs/wnm-cron.log 2>&1
Linux (root):
sudo crontab -e
# Add: */1 * * * * /opt/wnm/.venv/bin/wnm >> /var/log/wnm-cron.log 2>&1
Development Mode
For development with live code reloading:
macOS (native):
python3 -m wnm --dry_run
Linux (Docker):
./scripts/dev.sh
# Inside container:
python3 -m wnm --dry_run
See DOCKER-DEV.md for comprehensive Docker development workflow.
Platform Support
See PLATFORM-SUPPORT.md for detailed information about:
- Platform-specific process managers (systemd, launchd, setsid)
- Firewall management (UFW, null)
- Path conventions per platform
- Binary management and upgrades
- Testing strategies
Contributing
Contributions are welcome! Please submit a pull request or open an issue for any enhancements or bug fixes.
License
This project is licensed under the MIT License. See the LICENSE file for more details.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file wnm-0.6.1.tar.gz.
File metadata
- Download URL: wnm-0.6.1.tar.gz
- Upload date:
- Size: 123.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
19e330956d6215b507fa9c5acf0f69aebee7d1994e6339c779f6ea794b2c703e
|
|
| MD5 |
1f336e87c57b717e712932cdb29409ad
|
|
| BLAKE2b-256 |
a0929a7ab82ea28d92d52e476fd85dbc04c3f23804db6f9896562be586436fd0
|
File details
Details for the file wnm-0.6.1-py3-none-any.whl.
File metadata
- Download URL: wnm-0.6.1-py3-none-any.whl
- Upload date:
- Size: 99.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.0
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4ef532dc48717d34f71e568fdf023a8ddfc9dc1f6dc3d78d49d678649bb259e0
|
|
| MD5 |
276b06b82c55cb050c450a303b9b42ad
|
|
| BLAKE2b-256 |
8ad89e39e186a1d367f926aca7cc99a89c83b167c297c53de89228e01ff62d4b
|