diff --git a/immich/.env b/immich/.env index cb67855..6d6fd1e 100755 --- a/immich/.env +++ b/immich/.env @@ -1,13 +1,14 @@ -# You can find documentation for all the supported env variables at https://immich.app/docs/install/environment-variables +# You can find documentation for all the supported env variables at https://docs.immich.app/install/environment-variables # The location where your uploaded files are stored UPLOAD_LOCATION=./library -# The location where your database files are stored + +# The location where your database files are stored. Network shares are not supported for the database DB_DATA_LOCATION=./postgres # To set a timezone, uncomment the next line and change Etc/UTC to a TZ identifier from this list: https://en.wikipedia.org/wiki/List_of_tz_database_time_zones#List # TZ=Etc/UTC -TZ=Europe/Bratislava + # The Immich version to use. You can pin this to a specific version like "v1.71.0" IMMICH_VERSION=release @@ -19,9 +20,3 @@ DB_PASSWORD=postgres ################################################################################### DB_USERNAME=postgres DB_DATABASE_NAME=immich -IMMICH_INSTANCE_URL=https://immich.sectorq.eu/api -IMMICH_API_KEY=l4c1j4yd33Du5lo -APPNAME=immich - -HW_MODE1=vaapi -HW_MODE2=openvino diff --git a/immich/docker-compose.yml b/immich/docker-compose.yml index 41cf452..b4ff05f 100755 --- a/immich/docker-compose.yml +++ b/immich/docker-compose.yml @@ -1,88 +1,74 @@ +# +# WARNING: To install Immich, follow our guide: https://docs.immich.app/install/docker-compose +# +# Make sure to use the docker-compose.yml of the current release: +# +# https://github.com/immich-app/immich/releases/latest/download/docker-compose.yml +# +# The compose file on main may not be compatible with the latest release. + name: immich + services: - database: - 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 - container_name: immich_postgres - env_file: - - stack.env - environment: - POSTGRES_INITDB_ARGS: --data-checksums - healthcheck: - interval: 5m - start_interval: 30s - start_period: 5m - test: pg_isready --dbname="$${DB_PASSWORD}" --username="$${DB_USERNAME}" || - exit 1; Chksum="$$(psql --dbname="$${DB_DATABASE_NAME}" --username="$${DB_USERNAME}" - --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 - image: ${DOCKER_REGISTRY:-}docker.io/tensorchord/pgvecto-rs:pg14-v0.2.0 - labels: - wud.watch: false - wud.watch.digest: false - restart: ${RESTART:-unless-stopped} - volumes: - - /share/docker_data/immich/db:/var/lib/postgresql/data - immich-machine-learning: - container_name: immich_machine_learning - env_file: - - stack.env - extends: - file: hwaccel.ml.yml - service: ${HW_MODE2:-cpu} - healthcheck: - disable: false - image: ${DOCKER_REGISTRY:-}ghcr.io/immich-app/immich-machine-learning:${IMMICH_VERSION:-release} - labels: - wud.watch: false - wud.watch.digest: false - restart: ${RESTART:-unless-stopped} - volumes: - - model-cache:/cache immich-server: container_name: immich_server - depends_on: - - redis - - database + image: ghcr.io/immich-app/immich-server:${IMMICH_VERSION:-release} + # extends: + # file: hwaccel.transcoding.yml + # service: cpu # set to one of [nvenc, quicksync, rkmpp, vaapi, vaapi-wsl] for accelerated transcoding + volumes: + # 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 + - ${UPLOAD_LOCATION}:/data + - /etc/localtime:/etc/localtime:ro env_file: - - stack.env - extends: - file: hwaccel.transcoding.yml - service: ${HW_MODE1:-cpu} + - .env + ports: + - '2283:2283' + depends_on: + - redis + - database + restart: always healthcheck: disable: false - image: ${DOCKER_REGISTRY:-}ghcr.io/immich-app/immich-server:${IMMICH_VERSION:-release} - labels: - homepage.container: immich_server - homepage.description: Photo server - homepage.group: Media - homepage.href: https://${APPNAME}.sectorq.eu - homepage.icon: ${APPNAME}.png - homepage.name: Immich - homepage.server: my-docker - homepage.widget.key: wVxjlztA8MpeuzKkNGCSUPK2WjAY55qq4cfs9Zr5opU - homepage.widget.type: ${APPNAME} - homepage.widget.url: https://${APPNAME}.sectorq.eu - homepage.widget.version: '2' - #wud.watch: true - # wud.watch.digest: true - ports: - - 2283:2283 - restart: ${RESTART:-unless-stopped} + + immich-machine-learning: + container_name: immich_machine_learning + # For hardware acceleration, add one of -[armnn, cuda, rocm, openvino, rknn] to the image tag. + # Example tag: ${IMMICH_VERSION:-release}-cuda + image: ghcr.io/immich-app/immich-machine-learning:${IMMICH_VERSION:-release} + # extends: # uncomment this section for hardware acceleration - see https://docs.immich.app/features/ml-hardware-acceleration + # file: hwaccel.ml.yml + # service: cpu # set to one of [armnn, cuda, rocm, openvino, openvino-wsl, rknn] for accelerated inference - use the `-wsl` version for WSL2 where applicable volumes: - - /share/docker_data/immich/library:/usr/src/app/upload - - /media/nas/nas-photo:/mnt/photos2 - - /etc/localtime:/etc/localtime:ro + - model-cache:/cache + env_file: + - .env + restart: always + healthcheck: + disable: false + redis: container_name: immich_redis + image: docker.io/valkey/valkey:8-bookworm@sha256:fea8b3e67b15729d4bb70589eb03367bab9ad1ee89c876f54327fc7c6e618571 healthcheck: test: redis-cli ping || exit 1 - image: ${DOCKER_REGISTRY:-}docker.io/redis:6.2-alpine - labels: - wud.watch: true - wud.watch.digest: true - restart: ${RESTART:-unless-stopped} + restart: always + + database: + container_name: immich_postgres + image: ghcr.io/immich-app/postgres:14-vectorchord0.4.3-pgvectors0.2.0@sha256:41eacbe83eca995561fe43814fd4891e16e39632806253848efaf04d3c8a8b84 + environment: + POSTGRES_PASSWORD: ${DB_PASSWORD} + POSTGRES_USER: ${DB_USERNAME} + POSTGRES_DB: ${DB_DATABASE_NAME} + POSTGRES_INITDB_ARGS: '--data-checksums' + # Uncomment the DB_STORAGE_TYPE: 'HDD' var if your database isn't stored on SSDs + # DB_STORAGE_TYPE: 'HDD' + 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 + - ${DB_DATA_LOCATION}:/var/lib/postgresql/data + shm_size: 128mb + restart: always + volumes: - model-cache: null + model-cache: