From 6eb5d2e95ea51905924fa4f5436ec2a45f214afc Mon Sep 17 00:00:00 2001 From: Matthew Momjian <50788000+mmomjian@users.noreply.github.com> Date: Mon, 29 Apr 2024 09:47:07 -0400 Subject: [PATCH] docs: update custom locations and cleanup backup/restore paths (#9148) * Create separate-storage.md * Update separate-storage.md * Update separate-storage.md * Update separate-storage.md * Update separate-storage.md * Update separate-storage.md * Update separate-storage.md * Update separate-storage.md * Update separate-storage.md * Update separate-storage.md * New article for docker storage on SSD * Update separate-storage.md * Update separate-storage.md * In the process, found errors in backup and restore * Update backup-and-restore.md * Update backup-and-restore.md * Update backup-and-restore.md * Update custom-locations.md * Update custom-locations.md * Update custom-locations.md * Update custom-locations.md * linting --- .../docs/administration/backup-and-restore.md | 43 +++++++++++-------- docs/docs/guides/custom-locations.md | 25 ++++++++--- 2 files changed, 43 insertions(+), 25 deletions(-) diff --git a/docs/docs/administration/backup-and-restore.md b/docs/docs/administration/backup-and-restore.md index 5c29f63791..ab9dcec830 100644 --- a/docs/docs/administration/backup-and-restore.md +++ b/docs/docs/administration/backup-and-restore.md @@ -105,12 +105,16 @@ Example: `gunzip < "/path/to/backup/dump.sql.gz" | sed "s/SELECT pg_catalog.set_ ## Filesystem -Immich stores two types of content in the filesystem: (1) original, unmodified content, and (2) generated content. Only the original content needs to be backed-up, which includes the following folders: +Immich stores two types of content in the filesystem: (1) original, unmodified assets (photos and videos), and (2) generated content. Only the original content needs to be backed-up, which is stored in the following folders: 1. `UPLOAD_LOCATION/library` 2. `UPLOAD_LOCATION/upload` 3. `UPLOAD_LOCATION/profile` +:::caution +If you moved some of these folders onto a different storage device, such as `profile/`, make sure to adjust the backup path to match your setup +::: + ### Asset Types and Storage Locations Some storage locations are impacted by the Storage Template. See below for more details. @@ -119,7 +123,8 @@ Some storage locations are impacted by the Storage Template. See below for more <TabItem value="Storage Template Off (Default)." label="Storage Template Off (Default)." default> :::note -`UPLOAD_LOCATION/library` folder is not used by default on new machines running version 1.92.0. These are if the system administrator activated the storage template engine, for [more info](https://github.com/immich-app/immich/releases/tag/v1.92.0#:~:text=the%20partner%E2%80%99s%20assets.-,Hardening%20storage%20template). +The `UPLOAD_LOCATION/library` folder is not used by default on new machines running version 1.92.0. It is used only if the system administrator activated the storage template engine, +for more info read the [release notes](https://github.com/immich-app/immich/releases/tag/v1.92.0#:~:text=the%20partner%E2%80%99s%20assets.-,Hardening%20storage%20template). ::: **1. User-Specific Folders:** @@ -131,16 +136,16 @@ Some storage locations are impacted by the Storage Template. See below for more - **Source Assets:** - Original assets uploaded through the browser interface & mobile & CLI. - - Stored in `/library/upload/<userID>`. + - Stored in `UPLOAD_LOCATION/upload/<userID>`. - **Avatar Images:** - User profile images. - - Stored in `/library/profile/<userID>`. + - Stored in `UPLOAD_LOCATION/profile/<userID>`. - **Thumbs Images:** - - Preview images (blurred, small, large) for each asset and thumbnails for recognized faces. - - Stored in `/library/thumbs/<userID>`. + - Preview images (small thumbnails and large previews) for each asset and thumbnails for recognized faces. + - Stored in `UPLOAD_LOCATION/thumbs/<userID>`. - **Encoded Assets:** - - By default, unless otherwise specified re-encoded video assets for wider compatibility. - - Stored in `/library/encoded-video/<userID>`. + - Videos that have been re-encoded from the original for wider compatibility. The original is not removed. + - Stored in `UPLOAD_LOCATION/encoded-video/<userID>`. </TabItem> <TabItem value="Storage Template On" label="Storage Template On"> @@ -148,34 +153,34 @@ Some storage locations are impacted by the Storage Template. See below for more :::note If you choose to activate the storage template engine, it will move all assets to `UPLOAD_LOCATION/library/<userID>`. -When you turn off the storage template engine, it will leave the assets in `UPLOAD_LOCATION/library/<userID>` and will not return them to `/library/upload`. -**New assets** will be saved to `/library/upload`. +When you turn off the storage template engine, it will leave the assets in `UPLOAD_LOCATION/library/<userID>` and will not return them to `UPLOAD_LOCATION/upload`. +**New assets** will be saved to `UPLOAD_LOCATION/upload`. ::: **1. User-Specific Folders:** - Each user has a unique string representing them. - - The main user is "Admin" (but only for `UPLOAD_LOCATION/library`) - - Other users have different string identifiers. -- You can find your user ID in Account Account Settings -> Account -> User ID. + - The administrator can set a Storage Label for a user, which will be used instead of `<userID>` for the `library/` folder. + - The Admin has a default storage label of `admin`. +- You can find your user ID and Storage Label in Account Account Settings -> Account -> User ID. **2. Asset Types and Storage Locations:** - **Source Assets:** - - Original assets uploaded through the browser interface & mobile & CLI. + - Original assets uploaded through the browser interface, mobile, and CLI. - Stored in `UPLOAD_LOCATION/library/<userID>`. - **Avatar Images:** - User profile images. - - Stored in `/library/profile/<userID>`. + - Stored in `UPLOAD_LOCATION/profile/<userID>`. - **Thumbs Images:** - Preview images (blurred, small, large) for each asset and thumbnails for recognized faces. - - Stored in `/library/thumbs/<userID>`. + - Stored in `UPLOCAD_LOCATION/thumbs/<userID>`. - **Encoded Assets:** - - By default, unless otherwise specified re-encoded video assets for wider compatibility . - - Stored in `/library/encoded-video/<userID>`. + - Videos that have been re-encoded from the original for wider compatibility. The original is not removed. + - Stored in `UPLOAD_LOCATION/encoded-video/<userID>`. - **Files in Upload Queue (Mobile):** - Files uploaded through mobile apps. - - Temporarily located in `/library/upload/<userID>`. + - Temporarily located in `UPLOAD_LOCATION/upload/<userID>`. - Transferred to `UPLOAD_LOCATION/library/<userID>` upon successful upload. </TabItem> diff --git a/docs/docs/guides/custom-locations.md b/docs/docs/guides/custom-locations.md index 5898120f26..3e70345caa 100644 --- a/docs/docs/guides/custom-locations.md +++ b/docs/docs/guides/custom-locations.md @@ -2,8 +2,8 @@ This guide explains storing generated and raw files with docker's volume mount in different locations. -:::note Backup -It is important to remember to update the backup settings after following the guide to back up the new backup paths if using automatic backup tools. +:::caution Backup +It is important to remember to update the backup settings after following the guide to back up the new backup paths if using automatic backup tools, especially `profile/`. ::: In our `.env` file, we will define variables that will help us in the future when we want to move to a more advanced server in the future @@ -12,10 +12,11 @@ In our `.env` file, we will define variables that will help us in the future whe # You can find documentation for all the supported env variables at https://immich.app/docs/install/environment-variables # Custom location where your uploaded, thumbnails, and transcoded video files are stored -- {UPLOAD_LOCATION}=./library -+ {UPLOAD_LOCATION}=/custom/location/on/your/system/ -+ {THUMB_LOCATION}=/custom/location/on/your/system/ -+ {ENCODED_VIDEO_LOCATION}=/custom/location/on/your/system/ +- UPLOAD_LOCATION=./library ++ UPLOAD_LOCATION=/custom/location/on/your/system/immich/immich_files ++ THUMB_LOCATION=/custom/location/on/your/system/immich/thumbs ++ ENCODED_VIDEO_LOCATION=/custom/location/on/your/system/immich/encoded-video ++ PROFILE_LOCATION=/custom/location/on/your/system/immich/profile ... ``` @@ -28,6 +29,7 @@ services: - ${UPLOAD_LOCATION}:/usr/src/app/upload + - ${THUMB_LOCATION}:/usr/src/app/upload/thumbs + - ${ENCODED_VIDEO_LOCATION}:/usr/src/app/upload/encoded-video ++ - ${PROFILE_LOCATION}:/usr/src/app/upload/profile - /etc/localtime:/etc/localtime:ro ... @@ -37,6 +39,7 @@ services: - ${UPLOAD_LOCATION}:/usr/src/app/upload + - ${THUMB_LOCATION}:/usr/src/app/upload/thumbs + - ${ENCODED_VIDEO_LOCATION}:/usr/src/app/upload/encoded-video ++ - ${PROFILE_LOCATION}:/usr/src/app/upload/profile - /etc/localtime:/etc/localtime:ro ``` @@ -47,4 +50,14 @@ docker compose down docker compose up -d ``` +:::note +Because of the underlying properties of docker bind mounts, it is not recommended to mount the `upload/` and `library/` folders as separate bind mounts if they are on the same device. +For this reason, we mount the HDD or network storage to `/usr/src/app/upload` and then mount the folders we want quick access to below this folder. + +The `thumbs/` folder contains both the small thumbnails shown in the timeline, and the larger previews shown when clicking into an image. These cannot be split up. + +The storage metrics of the Immich server will track the storage available at `UPLOAD_LOCATION`, +so the administrator should setup some kind of monitoring to make sure the SSD does not run out of space. The `profile/` folder is much smaller, typically less than 1 MB. +::: + Thanks to [Jrasm91](https://github.com/immich-app/immich/discussions/2110#discussioncomment-5477767) for writing the guide.