2022-12-05 17:43:21 +01:00
|
|
|
services:
|
2022-12-05 20:47:15 +01:00
|
|
|
|
2025-02-04 18:14:37 +01:00
|
|
|
{% include 'roles/docker-central-database/templates/services/' + database_type + '.yml.j2' %}
|
2025-01-28 16:54:39 +01:00
|
|
|
|
2024-01-19 15:12:18 +01:00
|
|
|
{% include 'templates/docker/services/redis.yml.j2' %}
|
2023-12-26 16:40:19 +01:00
|
|
|
|
2022-12-05 20:47:15 +01:00
|
|
|
celeryworker:
|
2025-01-28 16:54:39 +01:00
|
|
|
# Celery workers handle background tasks (such file imports or federation
|
|
|
|
# messaging). The more processes a worker gets, the more tasks
|
|
|
|
# can be processed in parallel. However, more processes also means
|
|
|
|
# a bigger memory footprint.
|
|
|
|
# By default, a worker will span a number of process equal to your number
|
|
|
|
# of CPUs. You can adjust this, by explicitly setting the --concurrency
|
|
|
|
# flag:
|
|
|
|
# celery -A funkwhale_api.taskapp worker -l INFO --concurrency=4
|
2025-02-04 22:37:07 +01:00
|
|
|
{% include 'roles/docker-compose/templates/services/base.yml.j2' %}
|
2025-02-03 13:22:53 +01:00
|
|
|
image: funkwhale/api:${FUNKWHALE_VERSION}
|
2022-12-05 20:47:15 +01:00
|
|
|
command: celery -A funkwhale_api.taskapp worker -l INFO --concurrency=${CELERYD_CONCURRENCY-0}
|
|
|
|
environment:
|
|
|
|
- C_FORCE_ROOT=true
|
|
|
|
volumes:
|
|
|
|
- "data:${MEDIA_ROOT}"
|
2025-01-28 16:54:39 +01:00
|
|
|
- "music:${MUSIC_DIRECTORY_PATH}:ro"
|
2024-01-19 15:12:18 +01:00
|
|
|
{% include 'templates/docker/container/depends-on-database-redis.yml.j2' %}
|
|
|
|
{% include 'templates/docker/container/networks.yml.j2' %}
|
2024-01-02 21:13:34 +01:00
|
|
|
|
2022-12-05 20:47:15 +01:00
|
|
|
celerybeat:
|
2025-02-04 22:37:07 +01:00
|
|
|
{% include 'roles/docker-compose/templates/services/base.yml.j2' %}
|
2025-02-03 13:22:53 +01:00
|
|
|
image: funkwhale/api:${FUNKWHALE_VERSION}
|
2022-12-05 20:47:15 +01:00
|
|
|
command: celery -A funkwhale_api.taskapp beat --pidfile= -l INFO
|
2024-01-19 15:12:18 +01:00
|
|
|
{% include 'templates/docker/container/depends-on-database-redis.yml.j2' %}
|
|
|
|
{% include 'templates/docker/container/networks.yml.j2' %}
|
2022-12-05 20:47:15 +01:00
|
|
|
|
|
|
|
api:
|
2025-02-04 22:37:07 +01:00
|
|
|
{% include 'roles/docker-compose/templates/services/base.yml.j2' %}
|
2025-02-03 13:22:53 +01:00
|
|
|
image: funkwhale/api:${FUNKWHALE_VERSION}
|
2022-12-05 20:47:15 +01:00
|
|
|
volumes:
|
2025-01-28 16:54:39 +01:00
|
|
|
- "music:${MUSIC_DIRECTORY_PATH}:ro"
|
2022-12-05 20:47:15 +01:00
|
|
|
- "data:${MEDIA_ROOT}"
|
2025-01-28 16:54:39 +01:00
|
|
|
- "static_root:${STATIC_ROOT}"
|
2022-12-05 20:47:15 +01:00
|
|
|
ports:
|
|
|
|
- "5000"
|
2024-01-19 15:12:18 +01:00
|
|
|
{% include 'templates/docker/container/depends-on-database-redis.yml.j2' %}
|
|
|
|
{% include 'templates/docker/container/networks.yml.j2' %}
|
2022-12-05 20:47:15 +01:00
|
|
|
|
|
|
|
front:
|
2025-02-04 22:37:07 +01:00
|
|
|
{% include 'roles/docker-compose/templates/services/base.yml.j2' %}
|
2025-02-03 13:22:53 +01:00
|
|
|
image: funkwhale/front:${FUNKWHALE_VERSION}
|
2022-12-05 20:47:15 +01:00
|
|
|
depends_on:
|
|
|
|
- api
|
|
|
|
environment:
|
|
|
|
# Override those variables in your .env file if needed
|
|
|
|
- "NGINX_MAX_BODY_SIZE=${NGINX_MAX_BODY_SIZE-100M}"
|
|
|
|
volumes:
|
|
|
|
- "data:${MEDIA_ROOT}:ro"
|
|
|
|
#- "${STATIC_ROOT}:${STATIC_ROOT}:ro"
|
2022-12-05 17:43:21 +01:00
|
|
|
ports:
|
2022-12-05 20:47:15 +01:00
|
|
|
# override those variables in your .env file if needed
|
|
|
|
- "${FUNKWHALE_API_IP}:${FUNKWHALE_API_PORT}:80"
|
2024-01-19 15:12:18 +01:00
|
|
|
{% include 'templates/docker/container/networks.yml.j2' %}
|
2025-01-28 16:54:39 +01:00
|
|
|
|
|
|
|
typesense:
|
2025-02-04 22:37:07 +01:00
|
|
|
{% include 'roles/docker-compose/templates/services/base.yml.j2' %}
|
2025-01-28 16:54:39 +01:00
|
|
|
image: typesense/typesense:0.24.0
|
|
|
|
volumes:
|
|
|
|
- ./typesense/data:/data
|
|
|
|
command: --data-dir /data --enable-cors
|
|
|
|
profiles:
|
|
|
|
- typesense
|
2023-12-31 11:14:18 +01:00
|
|
|
|
2024-01-19 15:12:18 +01:00
|
|
|
{% include 'templates/docker/compose/volumes.yml.j2' %}
|
2022-12-05 20:47:15 +01:00
|
|
|
data:
|
2025-01-28 16:54:39 +01:00
|
|
|
static_root:
|
2022-12-05 20:47:15 +01:00
|
|
|
redis:
|
2025-01-28 16:54:39 +01:00
|
|
|
music:
|
2023-12-31 11:14:18 +01:00
|
|
|
|
2024-01-19 15:12:18 +01:00
|
|
|
{% include 'templates/docker/compose/networks.yml.j2' %}
|