Compare commits
133 Commits
a29545ad3f
...
renovate/g
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
f3ed4fc925 | ||
|
|
8168134448 | ||
|
|
70b8b4bf7c | ||
|
|
f0631f3e3d | ||
| e827dd1bc9 | |||
|
|
30303aac3d | ||
| 30b2fe346d | |||
| f78e723fc2 | |||
| ed13bd3d0e | |||
|
|
a317e6d71e | ||
| 2840a154ef | |||
|
|
cb32a5cdfb | ||
| 74d45f4268 | |||
|
|
030376e19d | ||
| 0996c409bc | |||
| d36c60a8ea | |||
|
|
c597e79059 | ||
|
|
b6d9f4bf24 | ||
| 2efbef9b63 | |||
| 87820cf217 | |||
| f1dbf34563 | |||
|
|
3b7ac0fb88 | ||
|
|
4c3169a47e | ||
|
|
75eb0a61f7 | ||
| f6d307076d | |||
| 7189883ee2 | |||
| cd59eacbf9 | |||
|
|
b9df89c28b | ||
|
|
df00920a45 | ||
| deb5ad57bf | |||
| 5f64125fce | |||
| 721d68eb8e | |||
|
|
0232e1b92d | ||
|
|
fb65d4d166 | ||
| 926762e8da | |||
| c1137d48cf | |||
|
|
d62fa7541c | ||
|
|
0c7273cc85 | ||
|
|
15ab156317 | ||
|
|
ff0d2b5826 | ||
| 00009cc6d1 | |||
| 859682e840 | |||
| bbaa2ba898 | |||
| 752dda8de7 | |||
|
|
d2b1a20172 | ||
|
|
0b0577e086 | ||
|
|
cfb8871144 | ||
| eb7da6f2f8 | |||
| ff4147ae7e | |||
|
|
b384297dfe | ||
|
|
761a7a0472 | ||
| f82ab41fa2 | |||
| 8fbc35be25 | |||
|
|
411bf717f6 | ||
|
|
5a3a844f35 | ||
| 567b5bfee4 | |||
| b2e9924a9f | |||
|
|
983df96887 | ||
| a4b26cba94 | |||
|
|
d4c95eb202 | ||
|
|
7fac1d47b6 | ||
| ef3042ea40 | |||
|
|
7bb8f43642 | ||
| cbb931a3ec | |||
|
|
7b10f2a49b | ||
| 707d4f966f | |||
|
|
6e624b0b3e | ||
| 8e734143af | |||
|
|
4c78a877e8 | ||
| 5bbaf64fc8 | |||
| 922b2fc228 | |||
|
|
f5fdadff85 | ||
|
|
a6d0fe68ea | ||
|
|
7cf44249ba | ||
| d6bd91a9a3 | |||
| c9eefa1314 | |||
|
|
d1b94da293 | ||
| ce1d62870b | |||
|
|
3639b3ebe3 | ||
|
|
a0b57345c0 | ||
|
|
d8f27f69b7 | ||
|
|
258369d4f8 | ||
|
|
35a29ae199 | ||
|
|
6ffa2aa4b4 | ||
|
|
581a8dd635 | ||
|
|
9024bc15a7 | ||
|
|
c9aaef57c0 | ||
|
|
8895c9b72f | ||
|
|
0d20dc3153 | ||
|
|
8ae7ba2c7f | ||
| a8aa54e448 | |||
| 350e3a3aca | |||
|
|
7737fcf8b4 | ||
| c4966a439f | |||
| 492d7ec6e6 | |||
| 8625df0557 | |||
|
|
5884437ca0 | ||
|
|
5865b370fa | ||
|
|
561712d086 | ||
| 0ab6179227 | |||
| 60d1317746 | |||
| 55edc95a24 | |||
|
|
5c8bcb441a | ||
|
|
94c1ea0c13 | ||
| 73ce5a4b28 | |||
| c03d0720aa | |||
| eb8ad85446 | |||
|
|
04aac62220 | ||
|
|
60427a5b96 | ||
| 787aaef949 | |||
|
|
8a2a64ffaa | ||
|
|
1327647719 | ||
| f11ec00fd2 | |||
| 1e9519f90c | |||
| 062d010067 | |||
| 206d6cc605 | |||
| c12dcda276 | |||
| f32b2de1c8 | |||
|
|
b0d5210476 | ||
|
|
6f921a6d71 | ||
| 70de505518 | |||
| 2edf610c28 | |||
| 6944e8ae3a | |||
| 87fc7703fc | |||
| 29c2ab4d6c | |||
|
|
ef4ef3666a | ||
|
|
72a2c3ffc1 | ||
|
|
c35fe0c4d1 | ||
|
|
f0b70493f9 | ||
| aa1de14af5 | |||
|
|
9853537002 | ||
|
|
bd53a5e103 | ||
|
|
745c15ef9d |
@@ -1,6 +1,7 @@
|
|||||||
services:
|
services:
|
||||||
audiobookshelf:
|
audiobookshelf:
|
||||||
image: ghcr.io/advplyr/audiobookshelf:2.29.0
|
image: ghcr.io/advplyr/audiobookshelf:2.30.0
|
||||||
|
restart: always
|
||||||
ports:
|
ports:
|
||||||
- 13378:80
|
- 13378:80
|
||||||
volumes:
|
volumes:
|
||||||
|
|||||||
41
audiomuse/.env.example
Normal file
41
audiomuse/.env.example
Normal file
@@ -0,0 +1,41 @@
|
|||||||
|
# Copy this file to `.env` and fill in the values that match your setup.
|
||||||
|
# Docker Compose files under deployment/ read these variables to keep settings in one place.
|
||||||
|
#
|
||||||
|
# IMPORTANT:
|
||||||
|
# 1. This file must be named exactly ".env" (not .env.txt or .env.example)
|
||||||
|
# 2. It must be in the SAME directory as your docker-compose-*.yaml file
|
||||||
|
# 3. Do NOT use spaces around the = sign
|
||||||
|
# 4. Do NOT use quotes around values (unless required by the value itself)
|
||||||
|
# 5. After editing, restart containers: docker-compose down && docker-compose up -d
|
||||||
|
#
|
||||||
|
# SPECIAL CHARACTERS IN VALUES:
|
||||||
|
# If your password or API key contains special characters like: $ ` " ' \ # ! & * ( ) [ ] { } | ; < > ?
|
||||||
|
# you may need to:
|
||||||
|
# - Avoid quotes entirely: GEMINI_API_KEY=AIza$pecial!Key (usually works)
|
||||||
|
# - OR use single quotes if the value has $: GEMINI_API_KEY='AIza$pecial!Key'
|
||||||
|
# - OR escape with backslash: GEMINI_API_KEY=AIza\$pecial\!Key
|
||||||
|
# Most problematic characters: $ (variable expansion), ` (command substitution), " (string delimiter)
|
||||||
|
#
|
||||||
|
# TROUBLESHOOTING:
|
||||||
|
# If API keys don't work, verify:
|
||||||
|
# - File is named ".env" exactly (check with: ls -la)
|
||||||
|
# - No spaces: GEMINI_API_KEY=AIza... (not GEMINI_API_KEY = "AIza...")
|
||||||
|
# - No unescaped special characters (especially $ ` " ')
|
||||||
|
# - Restart containers after changing this file
|
||||||
|
# If all else fails, try hardcoding the value directly in docker-compose-*.yaml to isolate the issue
|
||||||
|
|
||||||
|
# --- Jellyfin ---
|
||||||
|
JELLYFIN_USER_ID=
|
||||||
|
JELLYFIN_TOKEN=
|
||||||
|
JELLYFIN_URL=https://jellyfin.smittenfeld.nl
|
||||||
|
|
||||||
|
# --- Shared backend configuration ---
|
||||||
|
AUDIOMUSE_POSTGRES_USER=audiomuse
|
||||||
|
AUDIOMUSE_POSTGRES_PASSWORD=
|
||||||
|
AUDIOMUSE_POSTGRES_DB=audiomusedb
|
||||||
|
#
|
||||||
|
## --- Remote worker integration ---
|
||||||
|
#WORKER_URL=http://worker.example.com:8029/worker
|
||||||
|
#WORKER_POSTGRES_HOST=server.example.com
|
||||||
|
#WORKER_REDIS_URL=redis://server.example.com:6379/0
|
||||||
|
|
||||||
127
audiomuse/docker-compose.yml
Normal file
127
audiomuse/docker-compose.yml
Normal file
@@ -0,0 +1,127 @@
|
|||||||
|
version: '3.8'
|
||||||
|
services:
|
||||||
|
# Redis service for RQ (task queue)
|
||||||
|
audiomuse-ai-redis:
|
||||||
|
image: redis:7-alpine
|
||||||
|
container_name: audiomuse-redis
|
||||||
|
ports:
|
||||||
|
- "6379:6379" # Expose Redis port to the host
|
||||||
|
volumes:
|
||||||
|
- redis-data:/data # Persistent storage for Redis data
|
||||||
|
networks:
|
||||||
|
- audiomuse
|
||||||
|
restart: unless-stopped
|
||||||
|
|
||||||
|
# PostgreSQL database service
|
||||||
|
audiomuse-ai-postgres:
|
||||||
|
image: postgres:15-alpine
|
||||||
|
container_name: audiomuse-postgres
|
||||||
|
env_file:
|
||||||
|
- .env
|
||||||
|
environment:
|
||||||
|
POSTGRES_USER: ${AUDIOMUSE_POSTGRES_USER}
|
||||||
|
POSTGRES_PASSWORD: ${AUDIOMUSE_POSTGRES_PASSWORD}
|
||||||
|
POSTGRES_DB: ${AUDIOMUSE_POSTGRES_DB}
|
||||||
|
# ports:
|
||||||
|
# - "5432:5432" # Expose PostgreSQL port to the host
|
||||||
|
volumes:
|
||||||
|
- postgres-data:/var/lib/postgresql/data # Persistent storage for PostgreSQL data
|
||||||
|
networks:
|
||||||
|
- audiomuse
|
||||||
|
restart: unless-stopped
|
||||||
|
|
||||||
|
# AudioMuse-AI Flask application service
|
||||||
|
audiomuse-ai-flask:
|
||||||
|
image: ghcr.io/neptunehub/audiomuse-ai:0.8.2 # Reflects deployment.yaml
|
||||||
|
container_name: audiomuse-ai-flask-app
|
||||||
|
ports:
|
||||||
|
- "8013:8000"
|
||||||
|
env_file:
|
||||||
|
- .env
|
||||||
|
environment:
|
||||||
|
SERVICE_TYPE: "flask" # Tells the container to run the Flask app
|
||||||
|
MEDIASERVER_TYPE: "jellyfin" # Specify the media server type
|
||||||
|
POSTGRES_USER: ${AUDIOMUSE_POSTGRES_USER}
|
||||||
|
POSTGRES_PASSWORD: ${AUDIOMUSE_POSTGRES_PASSWORD}
|
||||||
|
POSTGRES_DB: ${AUDIOMUSE_POSTGRES_DB}
|
||||||
|
POSTGRES_PORT: "5432"
|
||||||
|
POSTGRES_HOST: "audiomuse-ai-postgres" # Service name of the postgres container
|
||||||
|
REDIS_URL: "redis://audiomuse-ai-redis:6379/0" # Connects to the 'redis' service
|
||||||
|
AI_MODEL_PROVIDER: "OPENAI"
|
||||||
|
OPENAI_API_KEY: "any-random-string" # Dummy key to enable local model usage
|
||||||
|
OPENAI_SERVER_URL: "http://172.17.0.1:12434/engines/llama.cpp/v1/chat/completions" #This is the API endpoint for local DMR model from within the Docker container.
|
||||||
|
OPENAI_MODEL_NAME: "ai/qwen3:0.6B-Q4_0"
|
||||||
|
TEMP_DIR: "/app/temp_audio"
|
||||||
|
# Use tmpfs to process audio files in memory for better performance. this reduuces disk I/O but might use more RAM.
|
||||||
|
# Mounted directories are not shared between containers, so each container gets its own tmpfs instance.
|
||||||
|
# Increase tmpfs size for very large audio files as needed.
|
||||||
|
# If host RAM is limited, use a Docker volume instead of tmpfs.
|
||||||
|
# For more info on tmpfs: https://docs.docker.com/engine/storage/tmpfs/
|
||||||
|
tmpfs:
|
||||||
|
- /app/temp_audio:rw,size=1000m
|
||||||
|
depends_on:
|
||||||
|
- audiomuse-ai-redis
|
||||||
|
- audiomuse-ai-postgres
|
||||||
|
restart: unless-stopped
|
||||||
|
networks:
|
||||||
|
- audiomuse
|
||||||
|
models:
|
||||||
|
- llm # Specify that LLM models are used in this service
|
||||||
|
|
||||||
|
# AudioMuse-AI RQ Worker service
|
||||||
|
audiomuse-ai-worker:
|
||||||
|
image: ghcr.io/neptunehub/audiomuse-ai:0.8.2 # Reflects deployment.yaml
|
||||||
|
container_name: audiomuse-ai-worker-instance
|
||||||
|
env_file:
|
||||||
|
- .env
|
||||||
|
environment:
|
||||||
|
SERVICE_TYPE: "worker" # Tells the container to run the RQ worker
|
||||||
|
MEDIASERVER_TYPE: "jellyfin" # Specify the media server type
|
||||||
|
JELLYFIN_USER_ID: "${JELLYFIN_USER_ID}"
|
||||||
|
JELLYFIN_TOKEN: "${JELLYFIN_TOKEN}"
|
||||||
|
JELLYFIN_URL: "${JELLYFIN_URL}"
|
||||||
|
# DATABASE_URL is now constructed by config.py from the following:
|
||||||
|
POSTGRES_USER: ${AUDIOMUSE_POSTGRES_USER}
|
||||||
|
POSTGRES_PASSWORD: ${AUDIOMUSE_POSTGRES_PASSWORD}
|
||||||
|
POSTGRES_DB: ${AUDIOMUSE_POSTGRES_DB}
|
||||||
|
POSTGRES_PORT: "5432"
|
||||||
|
POSTGRES_HOST: "audiomuse-ai-postgres" # Service name of the postgres container
|
||||||
|
REDIS_URL: "redis://audiomuse-ai-redis:6379/0" # Connects to the 'redis' service
|
||||||
|
AI_MODEL_PROVIDER: "OPENAI"
|
||||||
|
OPENAI_API_KEY: "any-random-string" # Dummy key to enable local model usage
|
||||||
|
OPENAI_SERVER_URL: "http://172.17.0.1:12434/engines/llama.cpp/v1/chat/completions" #This is the API endpoint for local DMR model from within the Docker container.
|
||||||
|
OPENAI_MODEL_NAME: "ai/qwen3:0.6B-Q4_0"
|
||||||
|
TEMP_DIR: "/app/temp_audio"
|
||||||
|
# Use tmpfs to process audio files in memory for better performance. this reduuces disk I/O but might use more RAM.
|
||||||
|
# Mounted directories are not shared between containers, so each container gets its own tmpfs instance.
|
||||||
|
# Increase tmpfs size for very large audio files as needed.
|
||||||
|
# If host RAM is limited, use a Docker volume instead of tmpfs.
|
||||||
|
# For more info on tmpfs: https://docs.docker.com/engine/storage/tmpfs/
|
||||||
|
tmpfs:
|
||||||
|
- /app/temp_audio:rw,size=1000m
|
||||||
|
depends_on:
|
||||||
|
- audiomuse-ai-redis
|
||||||
|
- audiomuse-ai-postgres
|
||||||
|
restart: unless-stopped
|
||||||
|
networks:
|
||||||
|
- audiomuse
|
||||||
|
models:
|
||||||
|
- llm # Specify that LLM models are used in this service
|
||||||
|
|
||||||
|
# Using Docker Model Runner (DMR)
|
||||||
|
# - Make sure your Docker Engine version supports the AI features and that the docker-model-plugin is installed.
|
||||||
|
# - Follow Docker's setup guide: https://docs.docker.com/ai/model-runner/get-started/#docker-engine
|
||||||
|
# - Once DMR is configured, you can download and run AI models locally just like Docker images — no code changes to this compose file are required.
|
||||||
|
# - For model integration with docker-compose, see: https://docs.docker.com/ai/compose/models-and-compose/
|
||||||
|
models:
|
||||||
|
llm:
|
||||||
|
model: ai/qwen3:0.6B-Q4_0 # Lightweight local model for testing. Change as needed; if changed, ensure it matches OPENAI_MODEL_NAME.
|
||||||
|
|
||||||
|
|
||||||
|
# Define volumes for persistent data and temporary files
|
||||||
|
volumes:
|
||||||
|
redis-data:
|
||||||
|
postgres-data:
|
||||||
|
|
||||||
|
networks:
|
||||||
|
audiomuse:
|
||||||
@@ -1,5 +1,6 @@
|
|||||||
include:
|
include:
|
||||||
- audiobookshelf/docker-compose.yml
|
- audiobookshelf/docker-compose.yml
|
||||||
|
- audiomuse/docker-compose.yml
|
||||||
- baikal/docker-compose.yml
|
- baikal/docker-compose.yml
|
||||||
- gitea/docker-compose.yml
|
- gitea/docker-compose.yml
|
||||||
- immich/docker-compose.yml
|
- immich/docker-compose.yml
|
||||||
@@ -9,8 +10,7 @@ include:
|
|||||||
- pihole/docker-compose.yml
|
- pihole/docker-compose.yml
|
||||||
- pingvin/docker-compose.yml
|
- pingvin/docker-compose.yml
|
||||||
- pocketid/docker-compose.yml
|
- pocketid/docker-compose.yml
|
||||||
- searxng/docker-compose.yml
|
# - spliit/docker-compose.yml
|
||||||
- spliit/docker-compose.yml
|
|
||||||
- shlink/docker-compose.yml
|
- shlink/docker-compose.yml
|
||||||
- synapse/docker-compose.yml
|
- synapse/docker-compose.yml
|
||||||
- updater/docker-compose.yml
|
- updater/docker-compose.yml
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
services:
|
services:
|
||||||
gitea:
|
gitea:
|
||||||
container_name: gitea
|
container_name: gitea
|
||||||
image: gitea/gitea:1.24.5-rootless
|
image: gitea/gitea:1.25.1-rootless
|
||||||
restart: always
|
restart: always
|
||||||
volumes:
|
volumes:
|
||||||
- ${GITEA_DATA_LOCATION}:/var/lib/gitea
|
- ${GITEA_DATA_LOCATION}:/var/lib/gitea
|
||||||
@@ -14,7 +14,8 @@ services:
|
|||||||
- "3000:3000"
|
- "3000:3000"
|
||||||
- "2222:2222"
|
- "2222:2222"
|
||||||
gitea-runner:
|
gitea-runner:
|
||||||
image: gitea/act_runner:0.2.12
|
image: gitea/act_runner:0.2.13
|
||||||
|
restart: always
|
||||||
environment:
|
environment:
|
||||||
CONFIG_FILE: /config.yaml
|
CONFIG_FILE: /config.yaml
|
||||||
GITEA_INSTANCE_URL: "${GITEA_INSTANCE_URL}"
|
GITEA_INSTANCE_URL: "${GITEA_INSTANCE_URL}"
|
||||||
|
|||||||
@@ -1,8 +1,10 @@
|
|||||||
UPLOAD_LOCATION=
|
UPLOAD_LOCATION=
|
||||||
|
IMMICH_VERSION=
|
||||||
IMMICH_DB_LOCATION=
|
IMMICH_DB_LOCATION=
|
||||||
|
|
||||||
DB_USERNAME=
|
IMMICH_DB_HOSTNAME=
|
||||||
DB_PASSWORD=
|
IMMICH_POSTGRES_DB=
|
||||||
DB_DATABASE_NAME=
|
IMMICH_POSTGRES_USER=
|
||||||
|
IMMICH_POSTGRES_PASSWORD=
|
||||||
|
|
||||||
REDIS_HOSTNAME=
|
REDIS_HOSTNAME=
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
services:
|
services:
|
||||||
immich-server:
|
immich-server:
|
||||||
container_name: immich_server
|
container_name: immich_server
|
||||||
image: ghcr.io/immich-app/immich-server:v1.140.1
|
image: ghcr.io/immich-app/immich-server:v2.3.1
|
||||||
# extends:
|
# extends:
|
||||||
# file: hwaccel.transcoding.yml
|
# file: hwaccel.transcoding.yml
|
||||||
# service: cpu # set to one of [nvenc, quicksync, rkmpp, vaapi, vaapi-wsl] for accelerated transcoding
|
# service: cpu # set to one of [nvenc, quicksync, rkmpp, vaapi, vaapi-wsl] for accelerated transcoding
|
||||||
@@ -11,50 +11,49 @@ services:
|
|||||||
- /etc/localtime:/etc/localtime:ro
|
- /etc/localtime:/etc/localtime:ro
|
||||||
env_file:
|
env_file:
|
||||||
- .env
|
- .env
|
||||||
|
environment:
|
||||||
|
DB_HOSTNAME: ${IMMICH_DB_HOSTNAME}
|
||||||
|
DB_USERNAME: ${IMMICH_POSTGRES_USER}
|
||||||
|
DB_PASSWORD: ${IMMICH_POSTGRES_PASSWORD}
|
||||||
|
DB_DATABASE_NAME: ${IMMICH_POSTGRES_DB}
|
||||||
ports:
|
ports:
|
||||||
- '2283:2283'
|
- '2283:2283'
|
||||||
depends_on:
|
depends_on:
|
||||||
- redis
|
- redis
|
||||||
- database
|
- database
|
||||||
restart: always
|
restart: always
|
||||||
healthcheck:
|
|
||||||
disable: false
|
|
||||||
|
|
||||||
immich-machine-learning:
|
immich-machine-learning:
|
||||||
container_name: immich_machine_learning
|
container_name: immich_machine_learning
|
||||||
# For hardware acceleration, add one of -[armnn, cuda, openvino] to the image tag.
|
image: ghcr.io/immich-app/immich-machine-learning:v2.3.1
|
||||||
# Example tag: ${IMMICH_VERSION:-release}-cuda
|
|
||||||
image: ghcr.io/immich-app/immich-machine-learning:v1.140.1
|
|
||||||
# extends: # uncomment this section for hardware acceleration - see https://immich.app/docs/features/ml-hardware-acceleration
|
|
||||||
# file: hwaccel.ml.yml
|
|
||||||
# service: cpu # set to one of [armnn, cuda, openvino, openvino-wsl] for accelerated inference - use the `-wsl` version for WSL2 where applicable
|
|
||||||
volumes:
|
volumes:
|
||||||
- model-cache:/cache
|
- model-cache:/cache
|
||||||
env_file:
|
env_file:
|
||||||
- .env
|
- .env
|
||||||
restart: always
|
restart: always
|
||||||
healthcheck:
|
|
||||||
disable: false
|
|
||||||
|
|
||||||
redis:
|
redis:
|
||||||
container_name: immich_redis
|
container_name: immich_redis
|
||||||
image: docker.io/redis:7.4-alpine@sha256:1bf97f21f01b0e7bd4b7b34a26d3b9d8086e41e70c10f262e8a9e0b49b5116a0
|
image: docker.io/valkey/valkey:8@sha256:81db6d39e1bba3b3ff32bd3a1b19a6d69690f94a3954ec131277b9a26b95b3aa
|
||||||
healthcheck:
|
healthcheck:
|
||||||
test: redis-cli ping || exit 1
|
test: redis-cli ping || exit 1
|
||||||
restart: always
|
restart: always
|
||||||
|
|
||||||
database:
|
database:
|
||||||
container_name: immich_postgres
|
container_name: immich_postgres
|
||||||
image: ghcr.io/immich-app/postgres:14-vectorchord0.3.0-pgvectors0.2.0
|
image: ghcr.io/immich-app/postgres:16-vectorchord0.3.0-pgvectors0.2.0
|
||||||
environment:
|
environment:
|
||||||
POSTGRES_PASSWORD: ${DB_PASSWORD}
|
POSTGRES_USER: ${IMMICH_POSTGRES_USER}
|
||||||
POSTGRES_USER: ${DB_USERNAME}
|
POSTGRES_PASSWORD: ${IMMICH_POSTGRES_PASSWORD}
|
||||||
POSTGRES_DB: ${DB_DATABASE_NAME}
|
POSTGRES_DB: ${IMMICH_POSTGRES_DB}
|
||||||
POSTGRES_INITDB_ARGS: '--data-checksums'
|
POSTGRES_INITDB_ARGS: '--data-checksums'
|
||||||
DB_STORAGE_TYPE: 'HDD'
|
DB_STORAGE_TYPE: 'HDD'
|
||||||
|
ports:
|
||||||
|
- 5433:5432
|
||||||
volumes:
|
volumes:
|
||||||
# Do not edit the next line. If you want to change the database storage location on your system, edit the value of DB_DATA_LOCATION in the .env file
|
# Do not edit the next line. If you want to change the database storage location on your system, edit the value of DB_DATA_LOCATION in the .env file
|
||||||
- ${IMMICH_DB_LOCATION}:/var/lib/postgresql/data
|
- ${IMMICH_DB_LOCATION}:/var/lib/postgresql/data
|
||||||
|
shm_size: 128mb
|
||||||
restart: always
|
restart: always
|
||||||
|
|
||||||
volumes:
|
volumes:
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
services:
|
services:
|
||||||
jellyfin:
|
jellyfin:
|
||||||
image: jellyfin/jellyfin:10.10.7
|
image: jellyfin/jellyfin:10.11.3
|
||||||
user: ${JELLYFIN_USER_UID}:${JELLYFIN_USER_GID}
|
user: ${JELLYFIN_USER_UID}:${JELLYFIN_USER_GID}
|
||||||
network_mode: 'host'
|
network_mode: 'host'
|
||||||
restart: 'unless-stopped'
|
restart: always
|
||||||
env_file:
|
env_file:
|
||||||
- .env
|
- .env
|
||||||
environment:
|
environment:
|
||||||
|
|||||||
@@ -1,17 +1,19 @@
|
|||||||
services:
|
services:
|
||||||
nextcloud_db:
|
nextcloud_db:
|
||||||
image: docker.io/library/postgres:17
|
image: docker.io/library/postgres:17
|
||||||
restart: unless-stopped
|
restart: always
|
||||||
volumes:
|
volumes:
|
||||||
- ${NEXTCLOUD_POSTGRES_DATA_DIR}:/var/lib/postgresql/data
|
- ${NEXTCLOUD_POSTGRES_DATA_DIR}:/var/lib/postgresql/data
|
||||||
environment:
|
environment:
|
||||||
POSTGRES_DB: ${NEXTCLOUD_POSTGRES_DB}
|
POSTGRES_DB: ${NEXTCLOUD_POSTGRES_DB}
|
||||||
POSTGRES_USER: ${NEXTCLOUD_POSTGRES_USER}
|
POSTGRES_USER: ${NEXTCLOUD_POSTGRES_USER}
|
||||||
POSTGRES_PASSWORD: ${NEXTCLOUD_POSTGRES_PASSWORD}
|
POSTGRES_PASSWORD: ${NEXTCLOUD_POSTGRES_PASSWORD}
|
||||||
|
ports:
|
||||||
|
- 5438:5432
|
||||||
networks:
|
networks:
|
||||||
- nextcloud
|
- nextcloud
|
||||||
nextcloud:
|
nextcloud:
|
||||||
image: nextcloud:31.0.7
|
image: nextcloud:32.0.1
|
||||||
restart: always
|
restart: always
|
||||||
ports:
|
ports:
|
||||||
- 8081:80
|
- 8081:80
|
||||||
@@ -30,12 +32,12 @@ services:
|
|||||||
networks:
|
networks:
|
||||||
- nextcloud
|
- nextcloud
|
||||||
cron:
|
cron:
|
||||||
image: nextcloud:31.0.7
|
image: nextcloud:32.0.1
|
||||||
container_name: nextcloud-cron
|
container_name: nextcloud-cron
|
||||||
volumes:
|
volumes:
|
||||||
- ${NEXTCLOUD_DATA_DIR}:/var/www/html
|
- ${NEXTCLOUD_DATA_DIR}:/var/www/html
|
||||||
entrypoint: /cron.sh
|
entrypoint: /cron.sh
|
||||||
restart: unless-stopped
|
restart: always
|
||||||
networks:
|
networks:
|
||||||
- nextcloud
|
- nextcloud
|
||||||
nextcloud-redis:
|
nextcloud-redis:
|
||||||
|
|||||||
@@ -9,9 +9,9 @@ PAPERLESS_SECRET_KEY=
|
|||||||
|
|
||||||
PAPERLESS_URL=
|
PAPERLESS_URL=
|
||||||
|
|
||||||
POSTGRES_DB=
|
PAPERLESS_POSTGRES_DB=
|
||||||
POSTGRES_USER=
|
PAPERLESS_POSTGRES_USER=
|
||||||
POSTGRES_PASSWORD=
|
PAPERLESS_POSTGRES_PASSWORD=
|
||||||
|
|
||||||
#optional
|
#optional
|
||||||
PAPERLESS_TIME_ZONE=
|
PAPERLESS_TIME_ZONE=
|
||||||
|
|||||||
@@ -1,23 +1,25 @@
|
|||||||
services:
|
services:
|
||||||
broker:
|
broker:
|
||||||
image: docker.io/library/redis:7
|
image: docker.io/library/redis:7
|
||||||
restart: unless-stopped
|
restart: always
|
||||||
volumes:
|
volumes:
|
||||||
- ${PAPERLESS_REDIS_DATA_DIR}:/data
|
- ${PAPERLESS_REDIS_DATA_DIR}:/data
|
||||||
|
|
||||||
db:
|
db:
|
||||||
image: docker.io/library/postgres:17
|
image: docker.io/library/postgres:17
|
||||||
restart: unless-stopped
|
restart: always
|
||||||
volumes:
|
volumes:
|
||||||
- ${PAPERLESS_POSTGRES_DATA_DIR}:/var/lib/postgresql/data
|
- ${PAPERLESS_POSTGRES_DATA_DIR}:/var/lib/postgresql/data
|
||||||
environment:
|
environment:
|
||||||
POSTGRES_DB: ${POSTGRES_DB}
|
POSTGRES_DB: ${PAPERLESS_POSTGRES_DB}
|
||||||
POSTGRES_USER: ${POSTGRES_USER}
|
POSTGRES_USER: ${PAPERLESS_POSTGRES_USER}
|
||||||
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD}
|
POSTGRES_PASSWORD: ${PAPERLESS_POSTGRES_PASSWORD}
|
||||||
|
ports:
|
||||||
|
- 5434:5432
|
||||||
|
|
||||||
paperless:
|
paperless:
|
||||||
image: ghcr.io/paperless-ngx/paperless-ngx:2.18.2
|
image: ghcr.io/paperless-ngx/paperless-ngx:2.19.4
|
||||||
restart: unless-stopped
|
restart: always
|
||||||
depends_on:
|
depends_on:
|
||||||
- db
|
- db
|
||||||
- broker
|
- broker
|
||||||
@@ -34,9 +36,9 @@ services:
|
|||||||
environment:
|
environment:
|
||||||
PAPERLESS_REDIS: redis://broker:6379
|
PAPERLESS_REDIS: redis://broker:6379
|
||||||
PAPERLESS_DBHOST: db
|
PAPERLESS_DBHOST: db
|
||||||
PAPERLESS_DBNAME: ${POSTGRES_DB}
|
PAPERLESS_DBNAME: ${PAPERLESS_POSTGRES_DB}
|
||||||
PAPERLESS_DBUSER: ${POSTGRES_USER}
|
PAPERLESS_DBUSER: ${PAPERLESS_POSTGRES_USER}
|
||||||
PAPERLESS_DBPASS: ${POSTGRES_PASSWORD}
|
PAPERLESS_DBPASS: ${PAPERLESS_POSTGRES_PASSWORD}
|
||||||
PAPERLESS_TIKA_ENABLED: 1
|
PAPERLESS_TIKA_ENABLED: 1
|
||||||
PAPERLESS_TIKA_GOTENBERG_ENDPOINT: http://gotenberg:3000
|
PAPERLESS_TIKA_GOTENBERG_ENDPOINT: http://gotenberg:3000
|
||||||
PAPERLESS_TIKA_ENDPOINT: http://tika:9998
|
PAPERLESS_TIKA_ENDPOINT: http://tika:9998
|
||||||
@@ -47,8 +49,8 @@ services:
|
|||||||
PAPERLESS_REDIRECT_LOGIN_TO_SSO: true
|
PAPERLESS_REDIRECT_LOGIN_TO_SSO: true
|
||||||
|
|
||||||
gotenberg:
|
gotenberg:
|
||||||
image: docker.io/gotenberg/gotenberg:8.23.0
|
image: docker.io/gotenberg/gotenberg:8.24.0
|
||||||
restart: unless-stopped
|
restart: always
|
||||||
|
|
||||||
# The gotenberg chromium route is used to convert .eml files. We do not
|
# The gotenberg chromium route is used to convert .eml files. We do not
|
||||||
# want to allow external content like tracking pixels or even javascript.
|
# want to allow external content like tracking pixels or even javascript.
|
||||||
@@ -58,5 +60,5 @@ services:
|
|||||||
- "--chromium-allow-list=file:///tmp/.*"
|
- "--chromium-allow-list=file:///tmp/.*"
|
||||||
|
|
||||||
tika:
|
tika:
|
||||||
image: docker.io/apache/tika:3.2.2.0
|
image: docker.io/apache/tika:3.2.3.0
|
||||||
restart: unless-stopped
|
restart: always
|
||||||
|
|||||||
@@ -2,7 +2,7 @@
|
|||||||
services:
|
services:
|
||||||
pihole:
|
pihole:
|
||||||
container_name: pihole
|
container_name: pihole
|
||||||
image: pihole/pihole:2025.06.1
|
image: pihole/pihole:2025.11.0
|
||||||
ports:
|
ports:
|
||||||
# DNS Ports
|
# DNS Ports
|
||||||
- "53:53/tcp"
|
- "53:53/tcp"
|
||||||
@@ -34,4 +34,4 @@ services:
|
|||||||
# - SYS_TIME
|
# - SYS_TIME
|
||||||
# Optional, if Pi-hole should get some more processing time
|
# Optional, if Pi-hole should get some more processing time
|
||||||
- SYS_NICE
|
- SYS_NICE
|
||||||
restart: unless-stopped
|
restart: always
|
||||||
@@ -1,7 +1,7 @@
|
|||||||
services:
|
services:
|
||||||
pingvin:
|
pingvin:
|
||||||
image: stonith404/pingvin-share:v1.13.0
|
image: stonith404/pingvin-share:v1.13.0
|
||||||
restart: unless-stopped
|
restart: always
|
||||||
ports:
|
ports:
|
||||||
- 3042:3000
|
- 3042:3000
|
||||||
environment:
|
environment:
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
services:
|
services:
|
||||||
pocket-id:
|
pocket-id:
|
||||||
image: ghcr.io/pocket-id/pocket-id:v1.10.0
|
image: ghcr.io/pocket-id/pocket-id:v1.15.0
|
||||||
restart: unless-stopped
|
restart: always
|
||||||
env_file: .env
|
env_file: .env
|
||||||
ports:
|
ports:
|
||||||
- "3043:1411"
|
- "3043:1411"
|
||||||
|
|||||||
@@ -1,2 +0,0 @@
|
|||||||
SEARXNG_CONFIG_DIR=
|
|
||||||
SEARXNG_DATA_DIR=
|
|
||||||
@@ -1,11 +0,0 @@
|
|||||||
services:
|
|
||||||
searxng:
|
|
||||||
container_name: searxng
|
|
||||||
image: docker.io/searxng/searxng:latest
|
|
||||||
restart: unless-stopped
|
|
||||||
env_file: .env
|
|
||||||
ports:
|
|
||||||
- "8888:8080"
|
|
||||||
volumes:
|
|
||||||
- ${SEARXNG_CONFIG_DIR}:/etc/searxng/
|
|
||||||
- ${SEARXNG_DATA_DIR}:/var/cache/searxng/
|
|
||||||
@@ -1,8 +1,8 @@
|
|||||||
services:
|
services:
|
||||||
shlink:
|
shlink:
|
||||||
image: shlinkio/shlink:4.5
|
image: shlinkio/shlink:4.6
|
||||||
container_name: shlink
|
container_name: shlink
|
||||||
restart: unless-stopped
|
restart: always
|
||||||
ports:
|
ports:
|
||||||
- "8085:8080"
|
- "8085:8080"
|
||||||
environment:
|
environment:
|
||||||
@@ -20,10 +20,12 @@ services:
|
|||||||
shlink_db:
|
shlink_db:
|
||||||
image: postgres:17
|
image: postgres:17
|
||||||
container_name: shlink_db
|
container_name: shlink_db
|
||||||
restart: unless-stopped
|
restart: always
|
||||||
volumes:
|
volumes:
|
||||||
- ${SHLINK_POSTGRES_DIR}:/var/lib/postgresql/data
|
- ${SHLINK_POSTGRES_DIR}:/var/lib/postgresql/data
|
||||||
environment:
|
environment:
|
||||||
POSTGRES_DB: ${SHLINK_POSTGRES_DB}
|
POSTGRES_DB: ${SHLINK_POSTGRES_DB}
|
||||||
POSTGRES_USER: ${SHLINK_POSTGRES_USER}
|
POSTGRES_USER: ${SHLINK_POSTGRES_USER}
|
||||||
POSTGRES_PASSWORD: ${SHLINK_POSTGRES_PASSWORD}
|
POSTGRES_PASSWORD: ${SHLINK_POSTGRES_PASSWORD}
|
||||||
|
ports:
|
||||||
|
- 5436:5432
|
||||||
|
|||||||
@@ -1,6 +1,7 @@
|
|||||||
services:
|
services:
|
||||||
spliit:
|
spliit:
|
||||||
image: petersmit27/spliit:latest
|
image: ghcr.io/spliit-app/spliit:1.19.1
|
||||||
|
restart: always
|
||||||
ports:
|
ports:
|
||||||
- 3001:3000
|
- 3001:3000
|
||||||
depends_on:
|
depends_on:
|
||||||
@@ -15,8 +16,11 @@ services:
|
|||||||
POSTGRES_PASSWORD: ${SPLIIT_POSTGRES_PASSWORD}
|
POSTGRES_PASSWORD: ${SPLIIT_POSTGRES_PASSWORD}
|
||||||
spliit_db:
|
spliit_db:
|
||||||
image: postgres:17
|
image: postgres:17
|
||||||
|
restart: always
|
||||||
volumes:
|
volumes:
|
||||||
- ${SPLIIT_POSTGRES_DIR}:/var/lib/postgresql/data
|
- ${SPLIIT_POSTGRES_DIR}:/var/lib/postgresql/data
|
||||||
|
ports:
|
||||||
|
- 5437:5432
|
||||||
environment:
|
environment:
|
||||||
TZ: ${TZ}
|
TZ: ${TZ}
|
||||||
POSTGRES_DB: ${SPLIIT_POSTGRES_DB}
|
POSTGRES_DB: ${SPLIIT_POSTGRES_DB}
|
||||||
|
|||||||
@@ -1,9 +1,9 @@
|
|||||||
SYNAPSE_POSTGRES_DATA_DIR=
|
SYNAPSE_POSTGRES_DATA_DIR=
|
||||||
SYNAPSE_CONFIG_DIR=
|
SYNAPSE_CONFIG_DIR=
|
||||||
|
|
||||||
POSTGRES_DB=
|
SYNAPSE_POSTGRES_DB=
|
||||||
POSTGRES_USER=
|
SYNAPSE_POSTGRES_USER=
|
||||||
POSTGRES_PASSWORD=
|
SYNAPSE_POSTGRES_PASSWORD=
|
||||||
|
|
||||||
MAS_CONFIG_DIR=
|
MAS_CONFIG_DIR=
|
||||||
|
|
||||||
|
|||||||
@@ -9,56 +9,60 @@ services:
|
|||||||
- LIVEKIT_KEY=devkey
|
- LIVEKIT_KEY=devkey
|
||||||
- LIVEKIT_SECRET=${LIVEKIT_SECRET_KEY}
|
- LIVEKIT_SECRET=${LIVEKIT_SECRET_KEY}
|
||||||
- LIVEKIT_FULL_ACCESS_HOMESERVERS=${MATRIX_DOMAIN}
|
- LIVEKIT_FULL_ACCESS_HOMESERVERS=${MATRIX_DOMAIN}
|
||||||
restart: unless-stopped
|
restart: always
|
||||||
ports:
|
ports:
|
||||||
- 8071:8080
|
- 8071:8080
|
||||||
element-call-livekit:
|
element-call-livekit:
|
||||||
image: livekit/livekit-server:v1.9.0
|
image: livekit/livekit-server:v1.9.3
|
||||||
command: --config /etc/livekit.yaml
|
command: --config /etc/livekit.yaml
|
||||||
ports:
|
ports:
|
||||||
- "7880:7880/tcp"
|
- "7880:7880/tcp"
|
||||||
- "7881:7881/tcp"
|
- "7881:7881/tcp"
|
||||||
- "7882:7882/tcp"
|
- "7882:7882/tcp"
|
||||||
- "50100-50200:50100-50200/udp"
|
- "50100-50200:50100-50200/udp"
|
||||||
restart: unless-stopped
|
restart: always
|
||||||
volumes:
|
volumes:
|
||||||
- ${LIVEKIT_CONFIG_DIR}/config.yaml:/etc/livekit.yaml:ro
|
- ${LIVEKIT_CONFIG_DIR}/config.yaml:/etc/livekit.yaml:ro
|
||||||
mautrix-signal:
|
mautrix-signal:
|
||||||
container_name: mautrix-signal
|
container_name: mautrix-signal
|
||||||
image: dock.mau.dev/mautrix/signal:v0.8.6
|
image: dock.mau.dev/mautrix/signal:v0.2511.0
|
||||||
restart: unless-stopped
|
restart: always
|
||||||
volumes:
|
volumes:
|
||||||
- ${MAUTRIX_SIGNAL_DATA_DIR}:/data
|
- ${MAUTRIX_SIGNAL_DATA_DIR}:/data
|
||||||
mautrix-signal_db:
|
mautrix-signal_db:
|
||||||
image: docker.io/library/postgres:17
|
image: docker.io/library/postgres:17
|
||||||
restart: unless-stopped
|
restart: always
|
||||||
volumes:
|
volumes:
|
||||||
- ${MAUTRIX_SIGNAL_POSTGRES_DATA_DIR}:/var/lib/postgresql/data
|
- ${MAUTRIX_SIGNAL_POSTGRES_DATA_DIR}:/var/lib/postgresql/data
|
||||||
environment:
|
environment:
|
||||||
POSTGRES_DB: ${MAUTRIX_SIGNAL_POSTGRES_DB}
|
POSTGRES_DB: ${MAUTRIX_SIGNAL_POSTGRES_DB}
|
||||||
POSTGRES_USER: ${MAUTRIX_SIGNAL_POSTGRES_USER}
|
POSTGRES_USER: ${MAUTRIX_SIGNAL_POSTGRES_USER}
|
||||||
POSTGRES_PASSWORD: ${MAUTRIX_SIGNAL_POSTGRES_PASSWORD}
|
POSTGRES_PASSWORD: ${MAUTRIX_SIGNAL_POSTGRES_PASSWORD}
|
||||||
|
ports:
|
||||||
|
- 5439:5432
|
||||||
mautrix-whatsapp:
|
mautrix-whatsapp:
|
||||||
container_name: mautrix-whatsapp
|
container_name: mautrix-whatsapp
|
||||||
image: dock.mau.dev/mautrix/whatsapp:v0.12.4
|
image: dock.mau.dev/mautrix/whatsapp:v0.2511.0
|
||||||
#image: petersmit27/mautrix-whatsapp:latest
|
#image: petersmit27/mautrix-whatsapp:latest
|
||||||
restart: unless-stopped
|
restart: always
|
||||||
volumes:
|
volumes:
|
||||||
- ${MAUTRIX_WHATSAPP_DATA_DIR}:/data
|
- ${MAUTRIX_WHATSAPP_DATA_DIR}:/data
|
||||||
depends_on:
|
depends_on:
|
||||||
- mautrix-whatsapp_db
|
- mautrix-whatsapp_db
|
||||||
mautrix-whatsapp_db:
|
mautrix-whatsapp_db:
|
||||||
image: docker.io/library/postgres:17
|
image: docker.io/library/postgres:17
|
||||||
restart: unless-stopped
|
restart: always
|
||||||
volumes:
|
volumes:
|
||||||
- ${MAUTRIX_WHATSAPP_POSTGRES_DATA_DIR}:/var/lib/postgresql/data
|
- ${MAUTRIX_WHATSAPP_POSTGRES_DATA_DIR}:/var/lib/postgresql/data
|
||||||
environment:
|
environment:
|
||||||
POSTGRES_DB: ${MAUTRIX_WHATSAPP_POSTGRES_DB}
|
POSTGRES_DB: ${MAUTRIX_WHATSAPP_POSTGRES_DB}
|
||||||
POSTGRES_USER: ${MAUTRIX_WHATSAPP_POSTGRES_USER}
|
POSTGRES_USER: ${MAUTRIX_WHATSAPP_POSTGRES_USER}
|
||||||
POSTGRES_PASSWORD: ${MAUTRIX_WHATSAPP_POSTGRES_PASSWORD}
|
POSTGRES_PASSWORD: ${MAUTRIX_WHATSAPP_POSTGRES_PASSWORD}
|
||||||
|
ports:
|
||||||
|
- 5440:5432
|
||||||
mas:
|
mas:
|
||||||
image: ghcr.io/element-hq/matrix-authentication-service:1.1.0
|
image: ghcr.io/element-hq/matrix-authentication-service:1.6.0
|
||||||
restart: unless-stopped
|
restart: always
|
||||||
working_dir: /config
|
working_dir: /config
|
||||||
volumes:
|
volumes:
|
||||||
- ${MAS_CONFIG_DIR}:/config
|
- ${MAS_CONFIG_DIR}:/config
|
||||||
@@ -70,27 +74,31 @@ services:
|
|||||||
- mas_db
|
- mas_db
|
||||||
mas_db:
|
mas_db:
|
||||||
image: docker.io/library/postgres:17
|
image: docker.io/library/postgres:17
|
||||||
restart: unless-stopped
|
restart: always
|
||||||
volumes:
|
volumes:
|
||||||
- ${MAS_POSTGRES_DATA_DIR}:/var/lib/postgresql/data
|
- ${MAS_POSTGRES_DATA_DIR}:/var/lib/postgresql/data
|
||||||
environment:
|
environment:
|
||||||
POSTGRES_DB: ${MAS_POSTGRES_DB}
|
POSTGRES_DB: ${MAS_POSTGRES_DB}
|
||||||
POSTGRES_USER: ${MAS_POSTGRES_USER}
|
POSTGRES_USER: ${MAS_POSTGRES_USER}
|
||||||
POSTGRES_PASSWORD: ${MAS_POSTGRES_PASSWORD}
|
POSTGRES_PASSWORD: ${MAS_POSTGRES_PASSWORD}
|
||||||
|
ports:
|
||||||
|
- 5441:5432
|
||||||
synapse_db:
|
synapse_db:
|
||||||
image: docker.io/library/postgres:17
|
image: docker.io/library/postgres:17
|
||||||
restart: unless-stopped
|
restart: always
|
||||||
volumes:
|
volumes:
|
||||||
- ${SYNAPSE_POSTGRES_DATA_DIR}:/var/lib/postgresql/data
|
- ${SYNAPSE_POSTGRES_DATA_DIR}:/var/lib/postgresql/data
|
||||||
environment:
|
environment:
|
||||||
POSTGRES_DB: ${POSTGRES_DB}
|
POSTGRES_DB: ${SYNAPSE_POSTGRES_DB}
|
||||||
POSTGRES_USER: ${POSTGRES_USER}
|
POSTGRES_USER: ${SYNAPSE_POSTGRES_USER}
|
||||||
POSTGRES_PASSWORD: ${POSTGRES_PASSWORD}
|
POSTGRES_PASSWORD: ${SYNAPSE_POSTGRES_PASSWORD}
|
||||||
POSTGRES_INITDB_ARGS: '--encoding=UTF-8 --locale=C'
|
POSTGRES_INITDB_ARGS: '--encoding=UTF-8 --locale=C'
|
||||||
|
ports:
|
||||||
|
- 5442:5432
|
||||||
synapse:
|
synapse:
|
||||||
container_name: synapse
|
container_name: synapse
|
||||||
image: matrixdotorg/synapse:v1.137.0
|
image: matrixdotorg/synapse:v1.142.1
|
||||||
restart: unless-stopped
|
restart: always
|
||||||
volumes:
|
volumes:
|
||||||
- ${SYNAPSE_CONFIG_DIR}:/data
|
- ${SYNAPSE_CONFIG_DIR}:/data
|
||||||
ports:
|
ports:
|
||||||
|
|||||||
Reference in New Issue
Block a user