close CLOUD-137 <!-- This is an auto-generated comment: release notes by coderabbit.ai --> ## Summary by CodeRabbit - **New Features** - Introduced advanced workspace-scoped search and aggregation capabilities with support for complex queries, highlights, and pagination. - Added pluggable search providers: Elasticsearch and Manticoresearch. - New GraphQL queries, schema types, and resolver support for search and aggregation. - Enhanced configuration options for search providers in self-hosted and cloud deployments. - Added Docker Compose services and environment variables for Elasticsearch and Manticoresearch. - Integrated indexer service into deployment and CI workflows. - **Bug Fixes** - Improved error handling with new user-friendly error messages for search provider and indexer issues. - **Documentation** - Updated configuration examples and environment variable references for indexer and search providers. - **Tests** - Added extensive end-to-end and provider-specific tests covering indexing, searching, aggregation, deletion, and error cases. - Included snapshot tests and test fixtures for search providers. - **Chores** - Updated deployment scripts, Helm charts, and Kubernetes manifests to include indexer-related environment variables and secrets. <!-- end of auto-generated comment: release notes by coderabbit.ai -->
100 lines
2.8 KiB
YAML
100 lines
2.8 KiB
YAML
name: affine
|
|
services:
|
|
affine:
|
|
image: ghcr.io/toeverything/affine-graphql:${AFFINE_REVISION:-stable}
|
|
container_name: affine_server
|
|
ports:
|
|
- '${PORT:-3010}:3010'
|
|
depends_on:
|
|
redis:
|
|
condition: service_healthy
|
|
postgres:
|
|
condition: service_healthy
|
|
indexer:
|
|
condition: service_healthy
|
|
affine_migration:
|
|
condition: service_completed_successfully
|
|
volumes:
|
|
# custom configurations
|
|
- ${UPLOAD_LOCATION}:/root/.affine/storage
|
|
- ${CONFIG_LOCATION}:/root/.affine/config
|
|
env_file:
|
|
- .env
|
|
environment:
|
|
- REDIS_SERVER_HOST=redis
|
|
- DATABASE_URL=postgresql://${DB_USERNAME}:${DB_PASSWORD}@postgres:5432/${DB_DATABASE:-affine}
|
|
restart: unless-stopped
|
|
|
|
affine_migration:
|
|
image: ghcr.io/toeverything/affine-graphql:${AFFINE_REVISION:-stable}
|
|
container_name: affine_migration_job
|
|
volumes:
|
|
# custom configurations
|
|
- ${UPLOAD_LOCATION}:/root/.affine/storage
|
|
- ${CONFIG_LOCATION}:/root/.affine/config
|
|
command: ['sh', '-c', 'node ./scripts/self-host-predeploy.js']
|
|
env_file:
|
|
- .env
|
|
environment:
|
|
- REDIS_SERVER_HOST=redis
|
|
- DATABASE_URL=postgresql://${DB_USERNAME}:${DB_PASSWORD}@postgres:5432/${DB_DATABASE:-affine}
|
|
depends_on:
|
|
postgres:
|
|
condition: service_healthy
|
|
redis:
|
|
condition: service_healthy
|
|
indexer:
|
|
condition: service_healthy
|
|
|
|
redis:
|
|
image: redis
|
|
container_name: affine_redis
|
|
healthcheck:
|
|
test: ['CMD', 'redis-cli', '--raw', 'incr', 'ping']
|
|
interval: 10s
|
|
timeout: 5s
|
|
retries: 5
|
|
restart: unless-stopped
|
|
|
|
postgres:
|
|
image: postgres:16
|
|
container_name: affine_postgres
|
|
volumes:
|
|
- ${DB_DATA_LOCATION}:/var/lib/postgresql/data
|
|
environment:
|
|
POSTGRES_USER: ${DB_USERNAME}
|
|
POSTGRES_PASSWORD: ${DB_PASSWORD}
|
|
POSTGRES_DB: ${DB_DATABASE:-affine}
|
|
POSTGRES_INITDB_ARGS: '--data-checksums'
|
|
# you better set a password for you database
|
|
# or you may add 'POSTGRES_HOST_AUTH_METHOD=trust' to ignore postgres security policy
|
|
POSTGRES_HOST_AUTH_METHOD: trust
|
|
healthcheck:
|
|
test:
|
|
['CMD', 'pg_isready', '-U', "${DB_USERNAME}", '-d', "${DB_DATABASE:-affine}"]
|
|
interval: 10s
|
|
timeout: 5s
|
|
retries: 5
|
|
restart: unless-stopped
|
|
|
|
indexer:
|
|
image: manticoresearch/manticore:${MANTICORE_VERSION:-9.2.14}
|
|
container_name: affine_indexer
|
|
volumes:
|
|
- ${MANTICORE_DATA_LOCATION}:/var/lib/manticore
|
|
ulimits:
|
|
nproc: 65535
|
|
nofile:
|
|
soft: 65535
|
|
hard: 65535
|
|
memlock:
|
|
soft: -1
|
|
hard: -1
|
|
healthcheck:
|
|
test:
|
|
['CMD', 'wget', '-O-', 'http://127.0.0.1:9308']
|
|
interval: 10s
|
|
timeout: 5s
|
|
retries: 5
|
|
restart: unless-stopped
|