mirror of
https://github.com/danswer-ai/danswer.git
synced 2025-05-30 01:30:21 +02:00
129 lines
3.7 KiB
YAML
129 lines
3.7 KiB
YAML
version: '3'
|
|
services:
|
|
api_server:
|
|
image: danswer/danswer-backend:latest
|
|
build:
|
|
context: ../../backend
|
|
dockerfile: Dockerfile
|
|
command: >
|
|
/bin/sh -c "alembic upgrade head &&
|
|
echo \"Starting Danswer Api Server\" &&
|
|
uvicorn danswer.main:app --host 0.0.0.0 --port 8080"
|
|
depends_on:
|
|
- relational_db
|
|
- vector_db
|
|
- search_engine
|
|
restart: always
|
|
env_file:
|
|
- .env
|
|
environment:
|
|
- DOCUMENT_INDEX_TYPE=split
|
|
- POSTGRES_HOST=relational_db
|
|
- QDRANT_HOST=vector_db
|
|
- TYPESENSE_HOST=search_engine
|
|
volumes:
|
|
- local_dynamic_storage:/home/storage
|
|
- file_connector_tmp_storage:/home/file_connector_storage
|
|
- model_cache_torch:/root/.cache/torch/
|
|
- model_cache_nltk:/root/nltk_data/
|
|
- model_cache_huggingface:/root/.cache/huggingface/
|
|
background:
|
|
image: danswer/danswer-backend:latest
|
|
build:
|
|
context: ../../backend
|
|
dockerfile: Dockerfile
|
|
command: /usr/bin/supervisord
|
|
depends_on:
|
|
- relational_db
|
|
- vector_db
|
|
restart: always
|
|
env_file:
|
|
- .env
|
|
environment:
|
|
- DOCUMENT_INDEX_TYPE=split
|
|
- POSTGRES_HOST=relational_db
|
|
- QDRANT_HOST=vector_db
|
|
- TYPESENSE_HOST=search_engine
|
|
volumes:
|
|
- local_dynamic_storage:/home/storage
|
|
- file_connector_tmp_storage:/home/file_connector_storage
|
|
- model_cache_torch:/root/.cache/torch/
|
|
- model_cache_nltk:/root/nltk_data/
|
|
- model_cache_huggingface:/root/.cache/huggingface/
|
|
web_server:
|
|
image: danswer/danswer-web-server:latest
|
|
build:
|
|
context: ../../web
|
|
dockerfile: Dockerfile
|
|
depends_on:
|
|
- api_server
|
|
restart: always
|
|
env_file:
|
|
- .env
|
|
environment:
|
|
- INTERNAL_URL=http://api_server:8080
|
|
relational_db:
|
|
image: postgres:15.2-alpine
|
|
restart: always
|
|
# POSTGRES_USER and POSTGRES_PASSWORD should be set in .env file
|
|
env_file:
|
|
- .env
|
|
volumes:
|
|
- db_volume:/var/lib/postgresql/data
|
|
vector_db:
|
|
image: qdrant/qdrant:v1.3.0
|
|
restart: always
|
|
env_file:
|
|
- .env
|
|
environment:
|
|
- QDRANT__TELEMETRY_DISABLED=true
|
|
volumes:
|
|
- qdrant_volume:/qdrant/storage
|
|
search_engine:
|
|
image: typesense/typesense:0.24.1
|
|
restart: always
|
|
# TYPESENSE_API_KEY must be set in .env file
|
|
environment:
|
|
- TYPESENSE_DATA_DIR=/typesense/storage
|
|
env_file:
|
|
- .env
|
|
volumes:
|
|
- typesense_volume:/typesense/storage
|
|
nginx:
|
|
image: nginx:1.23.4-alpine
|
|
restart: always
|
|
# nginx will immediately crash with `nginx: [emerg] host not found in upstream`
|
|
# if api_server / web_server are not up
|
|
depends_on:
|
|
- api_server
|
|
- web_server
|
|
ports:
|
|
- "80:80"
|
|
- "443:443"
|
|
volumes:
|
|
- ../data/nginx:/etc/nginx/conf.d
|
|
- ../data/certbot/conf:/etc/letsencrypt
|
|
- ../data/certbot/www:/var/www/certbot
|
|
command: >
|
|
/bin/sh -c "envsubst '$$\{DOMAIN\}' < /etc/nginx/conf.d/app.conf.template > /etc/nginx/conf.d/app.conf
|
|
&& while :; do sleep 6h & wait $${!}; nginx -s reload; done & nginx -g \"daemon off;\""
|
|
env_file:
|
|
- .env.nginx
|
|
# follows https://pentacent.medium.com/nginx-and-lets-encrypt-with-docker-in-less-than-5-minutes-b4b8a60d3a71
|
|
certbot:
|
|
image: certbot/certbot
|
|
restart: always
|
|
volumes:
|
|
- ../data/certbot/conf:/etc/letsencrypt
|
|
- ../data/certbot/www:/var/www/certbot
|
|
entrypoint: "/bin/sh -c 'trap exit TERM; while :; do certbot renew; sleep 12h & wait $${!}; done;'"
|
|
volumes:
|
|
local_dynamic_storage:
|
|
file_connector_tmp_storage: # used to store files uploaded by the user temporarily while we are indexing them
|
|
db_volume:
|
|
qdrant_volume:
|
|
typesense_volume:
|
|
model_cache_torch:
|
|
model_cache_nltk:
|
|
model_cache_huggingface:
|