2023-11-18 18:43:10 +01:00
|
|
|
#
|
|
|
|
# WARNING: Make sure to use the docker-compose.yml of the current release:
|
|
|
|
#
|
|
|
|
# https://github.com/immich-app/immich/releases/latest/download/docker-compose.yml
|
|
|
|
#
|
2023-11-18 18:49:30 +01:00
|
|
|
# The compose file on main may not be compatible with the latest release.
|
2023-11-18 18:43:10 +01:00
|
|
|
#
|
|
|
|
|
2023-11-10 03:43:21 +01:00
|
|
|
name: immich
|
|
|
|
|
2022-02-03 21:42:27 +01:00
|
|
|
services:
|
2022-05-08 14:07:58 +02:00
|
|
|
immich-server:
|
2022-12-30 17:30:28 +01:00
|
|
|
container_name: immich_server
|
2023-05-31 03:53:24 +02:00
|
|
|
image: ghcr.io/immich-app/immich-server:${IMMICH_VERSION:-release}
|
2024-05-27 23:04:07 +02:00
|
|
|
# extends:
|
|
|
|
# file: hwaccel.transcoding.yml
|
|
|
|
# service: cpu # set to one of [nvenc, quicksync, rkmpp, vaapi, vaapi-wsl] for accelerated transcoding
|
2022-02-03 21:42:27 +01:00
|
|
|
volumes:
|
2024-07-30 04:24:47 +02:00
|
|
|
# Do not edit the next line. If you want to change the media storage location on your system, edit the value of UPLOAD_LOCATION in the .env file
|
2022-02-12 05:23:06 +01:00
|
|
|
- ${UPLOAD_LOCATION}:/usr/src/app/upload
|
2023-10-03 03:50:27 +02:00
|
|
|
- /etc/localtime:/etc/localtime:ro
|
2022-02-03 21:42:27 +01:00
|
|
|
env_file:
|
|
|
|
- .env
|
2023-11-18 05:13:36 +01:00
|
|
|
ports:
|
2024-10-09 22:01:52 +02:00
|
|
|
- '2283:2283'
|
2022-02-03 21:42:27 +01:00
|
|
|
depends_on:
|
|
|
|
- redis
|
|
|
|
- database
|
2022-05-21 09:23:55 +02:00
|
|
|
restart: always
|
2024-08-04 20:37:43 +02:00
|
|
|
healthcheck:
|
|
|
|
disable: false
|
2022-02-03 21:42:27 +01:00
|
|
|
|
2022-06-11 23:12:06 +02:00
|
|
|
immich-machine-learning:
|
2022-12-30 17:30:28 +01:00
|
|
|
container_name: immich_machine_learning
|
2024-01-22 00:22:39 +01:00
|
|
|
# For hardware acceleration, add one of -[armnn, cuda, openvino] to the image tag.
|
|
|
|
# Example tag: ${IMMICH_VERSION:-release}-cuda
|
2023-05-31 03:53:24 +02:00
|
|
|
image: ghcr.io/immich-app/immich-machine-learning:${IMMICH_VERSION:-release}
|
2024-01-22 00:22:39 +01:00
|
|
|
# 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
|
2022-03-27 21:58:54 +02:00
|
|
|
volumes:
|
2023-02-18 16:13:37 +01:00
|
|
|
- model-cache:/cache
|
2022-03-27 21:58:54 +02:00
|
|
|
env_file:
|
|
|
|
- .env
|
2022-05-21 09:23:55 +02:00
|
|
|
restart: always
|
2024-08-04 20:37:43 +02:00
|
|
|
healthcheck:
|
|
|
|
disable: false
|
2022-05-21 09:23:55 +02:00
|
|
|
|
2022-02-03 21:42:27 +01:00
|
|
|
redis:
|
|
|
|
container_name: immich_redis
|
2025-01-14 03:32:52 +01:00
|
|
|
image: docker.io/redis:6.2-alpine@sha256:905c4ee67b8e0aa955331960d2aa745781e6bd89afc44a8584bfd13bc890f0ae
|
2024-05-22 11:28:12 +02:00
|
|
|
healthcheck:
|
|
|
|
test: redis-cli ping || exit 1
|
2022-05-21 09:23:55 +02:00
|
|
|
restart: always
|
2022-02-03 21:42:27 +01:00
|
|
|
|
|
|
|
database:
|
|
|
|
container_name: immich_postgres
|
2024-05-20 16:58:47 +02:00
|
|
|
image: docker.io/tensorchord/pgvecto-rs:pg14-v0.2.0@sha256:90724186f0a3517cf6914295b5ab410db9ce23190a2d9d0b9dd6463e3fa298f0
|
2022-02-03 21:42:27 +01:00
|
|
|
environment:
|
|
|
|
POSTGRES_PASSWORD: ${DB_PASSWORD}
|
|
|
|
POSTGRES_USER: ${DB_USERNAME}
|
|
|
|
POSTGRES_DB: ${DB_DATABASE_NAME}
|
2024-05-11 17:11:14 +02:00
|
|
|
POSTGRES_INITDB_ARGS: '--data-checksums'
|
2022-02-03 21:42:27 +01:00
|
|
|
volumes:
|
2024-07-30 04:24:47 +02:00
|
|
|
# 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
|
2024-04-08 22:11:25 +02:00
|
|
|
- ${DB_DATA_LOCATION}:/var/lib/postgresql/data
|
2024-05-22 11:28:12 +02:00
|
|
|
healthcheck:
|
2024-11-26 15:59:56 +01:00
|
|
|
test: >-
|
|
|
|
pg_isready --dbname="$${POSTGRES_DB}" --username="$${POSTGRES_USER}" || exit 1;
|
|
|
|
Chksum="$$(psql --dbname="$${POSTGRES_DB}" --username="$${POSTGRES_USER}" --tuples-only --no-align
|
|
|
|
--command='SELECT COALESCE(SUM(checksum_failures), 0) FROM pg_stat_database')";
|
|
|
|
echo "checksum failure count is $$Chksum";
|
|
|
|
[ "$$Chksum" = '0' ] || exit 1
|
2024-05-22 11:28:12 +02:00
|
|
|
interval: 5m
|
|
|
|
start_interval: 30s
|
|
|
|
start_period: 5m
|
2024-11-26 15:59:56 +01:00
|
|
|
command: >-
|
|
|
|
postgres
|
|
|
|
-c shared_preload_libraries=vectors.so
|
|
|
|
-c 'search_path="$$user", public, vectors'
|
|
|
|
-c logging_collector=on
|
|
|
|
-c max_wal_size=2GB
|
|
|
|
-c shared_buffers=512MB
|
|
|
|
-c wal_compression=on
|
2024-05-22 11:28:12 +02:00
|
|
|
restart: always
|
2022-06-11 23:12:06 +02:00
|
|
|
|
2022-02-03 21:42:27 +01:00
|
|
|
volumes:
|
2023-02-18 16:13:37 +01:00
|
|
|
model-cache:
|