OrthoVennPlus Installation
This guide covers the normal installation path for OrthoVennPlus from the deployment package. It focuses on preparing the deployment directory, starting the platform, creating the administrator account, and checking that the workflow service is ready.
Requirements
Before installation, prepare:
- Docker and Docker Compose
- A Linux, macOS, or server host with enough CPU, memory, and disk space
- Reference database files if you plan to use built-in species or annotation features
- One browser-accessible web port
Recommended minimum for a small test deployment:
| Resource | Recommendation |
|---|---|
| CPU | 8 cores |
| Memory | 16 GB |
| Disk | 100 GB free space |
Quick Start
1. Get the Deployment Package
Clone or unpack the deployment package on the server:
git clone <orthovenn-build-repo> orthovennplus-build
cd orthovennplus-build
The deployment directory should use this layout:
orthovennplus-build/
|-- data/
| |-- refdb/
| | |-- go-basic.obo
| | |-- go_terms.tsv
| | |-- uniprot_sprot.fasta
| | |-- uniprot_sprot_annotation.dmnd
| | |-- uniprot_sprot_annotation.tsv
| | |-- uniprot_sprot_raw.tsv
| | |-- sonicparanoid2/
|-- run.sh
|-- docker-compose.yaml
|-- .env.example
|-- install_sonic_pfam_profiles.sh
|-- setup_uniprot_refdb.py
|-- install.md
The files under data/refdb are used by GO annotation and DIAMOND-based annotation. Keep them in this directory so the containers can mount them consistently.
2. Create the Environment File
The deployment package includes .env.example. Copy it to .env:
cp .env.example .env
Then replace passwords, ports, and the secret key. Review these key startup settings:
ORTHOVENN_IMAGE_TAG=latest
API_PORT=18008
# Web port opened by users in the browser.
NGINX_PORT=18088
POSTGRES_PORT=15435
REDIS_PORT=16379
POSTGRES_USER=orthovennplus
# Replace with a strong database password.
POSTGRES_PASSWORD=change-this-postgres-password
POSTGRES_DB=orthovennplus
# Required for login tokens. Use a long random value.
SECRET_KEY=change-this-secret-key
ACCESS_TOKEN_EXPIRE_MINUTES=4320
FIRST_REGISTERED_USER_AS_ADMIN=true
CELERY_CONCURRENCY=3
BLAST_WORKER_CONCURRENCY=2
# Default CPU threads used by analysis modules.
MODULE_DEFAULT_THREADS=16
MODULE_THREAD_EDITABLE=true
UPLOAD_MAX_FILE_SIZE=10737418240
# 0 means no species count limit.
PROJECT_SPECIES_LIMIT=20
3. Check Reference Data
Before starting the services, confirm that the required annotation files exist:
ls data/refdb/go-basic.obo
ls data/refdb/go_terms.tsv
ls data/refdb/uniprot_sprot_annotation.dmnd
ls data/refdb/uniprot_sprot_annotation.tsv
If the UniProt reference files are missing, generate them from the deployment directory:
python setup_uniprot_refdb.py
SonicParanoid2 works in graph-only mode by default. If you plan to use full SonicParanoid2 architecture/domain mode, install the optional Pfam profile database later from Optional SonicParanoid2 Pfam Profile DB.
4. Start with run.sh
The recommended startup command is run.sh. It creates required data directories, pulls images, runs database migrations, and starts the Docker Compose services:
If the script is not executable after unpacking a release package, run:
chmod +x run.sh
Start the services:
./run.sh
Use a specific image tag when deploying a released version:
./run.sh --tag 2026-06-02
Check the available options:
./run.sh --help
5. Open the Website
After the services start, open:
http://<server-ip>:5920
Check service status when needed:
docker compose ps
Manual Docker Compose Startup
Use this only when you do not want to use run.sh:
mkdir -p data/projects data/uploads data/uploads/tus data/tmp data/logs data/refdb data/builtin_db data/postgres
mkdir -p data/refdb/sonicparanoid2
docker compose up -d postgres redis
docker compose run --rm backend alembic upgrade head
docker compose up -d
Administrator Account
You need one administrator account to manage users, settings, workers, project cleanup, and gallery projects.
Private Deployment
For a trusted local or intranet deployment, you can let the first registered user become the administrator.
Set this before the first registration:
FIRST_REGISTERED_USER_AS_ADMIN=true
Start the services, open the website, and register the first account. After the administrator account is created, set it back to false and restart the backend:
FIRST_REGISTERED_USER_AS_ADMIN=false
docker compose restart backend
Public Deployment
For a public deployment, create the administrator with the backend CLI:
docker compose exec backend \
env ORTHOVENN_ADMIN_PASSWORD='your-strong-password' \
python -m app.cli create-admin \
--username admin \
--email admin@example.com
To promote an existing user:
docker compose exec backend \
env ORTHOVENN_ADMIN_PASSWORD='your-strong-password' \
python -m app.cli create-admin \
--username existing-user \
--email existing@example.com \
--promote-existing
Required Settings
Most deployments only need to review these settings:
| Area | Setting |
|---|---|
| Ports | API_PORT, NGINX_PORT, TUSD_PORT, POSTGRES_PORT, REDIS_PORT |
| Security | SECRET_KEY, administrator password, FIRST_REGISTERED_USER_AS_ADMIN |
MAIL_ENABLED, MAIL_SMTP_HOST, MAIL_SMTP_USERNAME, MAIL_SMTP_PASSWORD | |
| Upload | UPLOAD_TRANSPORT, UPLOAD_MAX_FILE_SIZE, PROJECT_SPECIES_LIMIT |
| Workers | CELERY_CONCURRENCY, BLAST_WORKER_CONCURRENCY, MODULE_DEFAULT_THREADS |
| Cleanup | PROJECT_CLEANUP_SCHEDULER_ENABLED and cleanup schedule variables |
Email verification login and password reset require SMTP. For 163 Mail, use the
SMTP authorization code as MAIL_SMTP_PASSWORD; do not use the web login
password.
Per-user project limits and project retention days are managed after login:
Admin -> Users
Reference databases are expected in the deployment package:
| Host Directory | Purpose |
|---|---|
data/refdb | GO, UniProt, DIAMOND annotation, and other reference files |
data/refdb/sonicparanoid2 | SonicParanoid2 optional resources from the deployment package |
data/builtin_db | Built-in species database, created or mounted when used |
Optional SonicParanoid2 Pfam Profile DB
SonicParanoid2 uses graph-only mode by default and does not need the Pfam profile database. Install the Pfam MMseqs profile database only if you plan to disable graph-only mode and run the full architecture/domain workflow.
Check the current status from the deployment directory:
./install_sonic_pfam_profiles.sh status
The script only uses these paths:
data/refdb/sonicparanoid2/downloads/
data/refdb/sonicparanoid2/pfam_profile_db/
The recommended path is manual download first, then local install.
Manual download address:
https://drive.google.com/file/d/1eV3t2FINOUPJI1132w3bmBrHnO3_bpfJ/view?usp=sharing
Save the archive as:
data/refdb/sonicparanoid2/downloads/sonicparanoid2_pfam_mmseqs_profile_db.tar.gz
Then verify and install:
mkdir -p data/refdb/sonicparanoid2/downloads
tar -tzf data/refdb/sonicparanoid2/downloads/sonicparanoid2_pfam_mmseqs_profile_db.tar.gz >/dev/null
./install_sonic_pfam_profiles.sh install
If the archive was downloaded to another location:
./install_sonic_pfam_profiles.sh install /path/to/sonicparanoid2_pfam_mmseqs_profile_db.tar.gz
If the server can access Google Drive directly, you can try downloading with curl:
mkdir -p data/refdb/sonicparanoid2/downloads
curl -L \
'https://drive.google.com/uc?id=1eV3t2FINOUPJI1132w3bmBrHnO3_bpfJ' \
-o data/refdb/sonicparanoid2/downloads/sonicparanoid2_pfam_mmseqs_profile_db.tar.gz
./install_sonic_pfam_profiles.sh install
If graph-only mode is disabled but the profile database is missing, the SonicParanoid2 task will stop early and report the missing profile database path.
Verify Installation
After logging in as administrator:
- Open Admin from the user menu.
- Check Workers and confirm the main workflow worker is visible.
- Check Settings for upload size, species limit, cleanup schedule, and thread defaults.
- Create a small test project and confirm the progress page updates module logs.
Useful log commands:
docker compose logs -f backend
docker compose logs -f celery_worker
docker compose logs -f blast_worker