ComputeHorde Validator. See repositories main README for explanation of what that means.
Skeleton of this project was generated with cookiecutter-rt-django
, which sometimes gets upgrades that are easy to retrofit into already older projects.
# 1st tab
$ ./setup-dev.sh
# 2nd tab
docker-compose up
# 1st tab
cd app/src
uv run manage.py wait_for_database --timeout 10
uv run manage.py migrate
Typically, when developing validator, you want to test:
- Scheduling synthetic jobs
- Settings weights
- Passing organic jobs from a facilitator to a miner
Some of these actions may require launching celery locally, which you can achieve by running start_celery.sh.
Some tests start celery in order to test obscure interprocess timeouts. That is generally automated, however celery workers being killed on MacOS yield an insufferable amount of error dialogs displayed on top of everything you have open. To save developers from suffering this fate, tests support running celery on a remote host, via ssh. A common case would be a local VM, also running postgres and redis. In such a case, make sure postgres and redis ports are forwarded so they are accessible from the host, which runs your code/tests. To make tests start celery on the remote host, define the following env vars (the author of this note suggests using direnv or PyCharm Run/Debug configuration templates for ease):
REMOTE_HOST=ubuntu-dev # ssh config entry name
REMOTE_VENV=/path/to/remote/venv # on the remote
REMOTE_CELERY_START_SCRIPT=/project/mount/ComputeHorde/validator/dev_env_setup/start_celery.sh # adjust the beginning
# to match your synced folders configuration
DEBUG_MINER_KEY=... python manage.py debug_run_synthetic_jobs
Create an Ubuntu server and use the install_miner.sh
script from the root of this repository to install the miner in a local mode:
curl -sSfL https://github.com/backend-developers-ltd/ComputeHorde/raw/master/install_miner.sh | bash -s - local SSH_DESTINATION VALIDATOR_PUBLIC_KEY MINER_PORT DEFAULT_EXECUTOR_CLASS
Replace the placeholders in the command above:
SSH_DESTINATION
: your server's connection info (i.e.username@1.2.3.4
)VALIDATOR_PUBLIC_KEY
: the hotkey of your validator (not the path to the key)MINER_PORT
(optional): the port (of your choosing) on which the miner will listen for incoming connections (default is 8000)DEFAULT_EXECUTOR_CLASS
(optional): specifies a custom executor class to use. For A6000 synthetic job support,always_on.llm.a6000
must be set
Trusted miners require S3 buckets to store prompts and answers.
Make sure you have AWS CLI installed and configured, to provision these buckets conveniently with the correct permissions pre-configured.
Then run the following script:
curl -sSfL https://github.com/backend-developers-ltd/ComputeHorde/raw/master/validator/provision_s3.sh | bash -s - PROMPTS_BUCKET ANSWERS_BUCKET --create-user
Replace PROMPTS_BUCKET
and ANSWERS_BUCKET
with the names of the S3 buckets you want to use for prompts and answers respectively.
It will automatically create a dedicated user, assign permissions policy for created buckets, and add an access key,
displaying it at the end so it can be copied to the validator .env
file.
If you don't want to create a user and prefer to handle permissions manually, skip the --create-user
option.
Note: if your buckets are not in your default AWS region export AWS_DEFAULT_REGION
before running the script (both buckets need to be in the same region), and add it to .env
later:
export AWS_DEFAULT_REGION=BUCKETS_REGION
At the end of the script, it will show the values for S3_BUCKET_NAME_PROMPTS
, S3_BUCKET_NAME_ANSWERS
.
If you use the --create-user
flag, it will also show the values for AWS_ACCESS_KEY_ID
and AWS_SECRET_ACCESS_KEY
.
opy these variables in your validator .env
file and restart your validator.
Warning
Even if you did not use --create-user
, you still need to provide AWS_ACCESS_KEY_ID
and AWS_SECRET_ACCESS_KEY
in your validator .env
file.
In that case, you will have to manually generate the credentials.
Note
We have tested the AWS S3. The buckets allow quick and concurrent upload and download of multiple (but tiny) text files.
Add or update these variables in the validator .env
file:
TRUSTED_MINER_ADDRESS="MINER_IP"
TRUSTED_MINER_PORT=MINER_PORT
If your buckets are not in the default AWS region, add also:
AWS_DEFAULT_REGION=BUCKETS_REGION