From c70d9f9055d0cb92f501785386f191458fb3ec5d Mon Sep 17 00:00:00 2001 From: Matthew Momjian <50788000+mmomjian@users.noreply.github.com> Date: Tue, 16 Apr 2024 18:58:19 -0400 Subject: [PATCH] docs: bunch of small changes (#8854) * Update postgres-standalone.md * Update postgres-standalone.md * Update postgres-standalone.md * Update postgres-standalone.md * Update environment-variables.md * Update postgres-standalone.md * Update docker-compose.mdx * Update environment-variables.md * Update FAQ.mdx * Update kubernetes.md * Update kubernetes.md * Update system-settings.md * Update libraries.md * Update supported-formats.md --- docs/docs/FAQ.mdx | 8 +++++--- .../docs/administration/postgres-standalone.md | 10 +++++++++- docs/docs/administration/system-settings.md | 4 +--- docs/docs/features/libraries.md | 2 +- docs/docs/features/supported-formats.md | 2 +- docs/docs/install/docker-compose.mdx | 14 +++++++++----- docs/docs/install/environment-variables.md | 18 ++++++++++++------ docs/docs/install/kubernetes.md | 2 +- 8 files changed, 39 insertions(+), 21 deletions(-) diff --git a/docs/docs/FAQ.mdx b/docs/docs/FAQ.mdx index 5583ae8b63..033863bf51 100644 --- a/docs/docs/FAQ.mdx +++ b/docs/docs/FAQ.mdx @@ -194,18 +194,18 @@ However, disabling all jobs will not disable the machine learning service itself ### I'm getting errors about models being corrupt or failing to download. What do I do? -You can delete the model cache volume, where models are downloaded. This will give the service a clean environment to download the model again. If models are failing to download entirely, you can manually download them from [Huggingface](https://huggingface.co/immich-app) and place them in the cache folder. +You can delete the model cache volume, where models are downloaded. This will give the service a clean environment to download the model again. If models are failing to download entirely, you can manually download them from [Huggingface][huggingface] and place them in the cache folder. ### Can I use a custom CLIP model? -No, this is not supported. Only models listed in the [Huggingface](https://huggingface.co/immich-app) page are compatible. Feel free to make a feature request if there's a model not listed here that you think should be added. +No, this is not supported. Only models listed in the [Huggingface][huggingface] page are compatible. Feel free to make a feature request if there's a model not listed here that you think should be added. ### I want to be able to search in other languages besides English. How can I do that? You can change to a multilingual model listed [here](https://huggingface.co/collections/immich-app/multilingual-clip-654eb08c2382f591eeb8c2a7) by going to Administration > Machine Learning Settings > Smart Search and replacing the name of the model. Be sure to re-run Smart Search on all assets after this change. You can then search in over 100 languages. :::note -Feel free to make a feature request if there's a model you want to use that isn't in [Immich Huggingface list](https://huggingface.co/immich-app). +Feel free to make a feature request if there's a model you want to use that isn't in [Immich Huggingface list][huggingface]. ::: ### Does Immich support Facial Recognition for videos? @@ -366,3 +366,5 @@ If your version of Immich is below 1.92.0 and the crash occurs after logs about ### Why does Immich log migration errors on startup? Sometimes Immich logs errors such as "duplicate key value violates unique constraint" or "column (...) of relation (...) already exists". Because of Immich's container structure, this error can be seen when both immich and immich-microservices start at the same time and attempt to migrate or create the database structure. Since the database migration is run sequentially and inside of transactions, this error message does not cause harm to your installation of Immich and can safely be ignored. If needed, you can manually restart Immich by running `docker restart immich immich-microservices`. + +[huggingface]: https://huggingface.co/immich-app diff --git a/docs/docs/administration/postgres-standalone.md b/docs/docs/administration/postgres-standalone.md index be8d883a1c..f5796879d0 100644 --- a/docs/docs/administration/postgres-standalone.md +++ b/docs/docs/administration/postgres-standalone.md @@ -10,9 +10,11 @@ Running with a pre-existing Postgres server can unlock powerful administrative f ## Prerequisites -You must install pgvecto.rs using their [instructions](https://docs.pgvecto.rs/getting-started/installation.html). After installation, add `shared_preload_libraries = 'vectors.so'` to your `postgresql.conf`. If you already have some `shared_preload_libraries` set, you can separate each extension with a comma. For example, `shared_preload_libraries = 'pg_stat_statements, vectors.so'`. +You must install pgvecto.rs into your instance of Postgres using their [instructions][vectors-install]. After installation, add `shared_preload_libraries = 'vectors.so'` to your `postgresql.conf`. If you already have some `shared_preload_libraries` set, you can separate each extension with a comma. For example, `shared_preload_libraries = 'pg_stat_statements, vectors.so'`. :::note +Immich is known to work with Postgres versions 14, 15, and 16. Earlier versions are unsupported. + Make sure the installed version of pgvecto.rs is compatible with your version of Immich. For example, if your Immich version uses the dedicated database image `tensorchord/pgvecto-rs:pg14-v0.2.1`, you must install pgvecto.rs `>= 0.2.1, < 0.3.0`. ::: @@ -30,6 +32,10 @@ DB_URL='postgresql://immichdbusername:immichdbpassword@postgreshost:postgresport # DB_URL='postgresql://immichdbusername:immichdbpassword@postgreshost:postgresport/immichdatabasename?sslmode=require&sslmode=no-verify' ``` +:::info +When `DB_URL` is defined, the other database (`DB_*`) variables are ignored, with the exception of `DB_VECTOR_EXTENSION`. +::: + ## With superuser permission Typically Immich expects superuser permission in the database, which you can grant by running `ALTER USER <immichdbusername> WITH SUPERUSER;` at the `psql` console. If you prefer not to grant superuser permissions, follow the instructions in the next section. @@ -64,3 +70,5 @@ When installing a new version of pgvecto.rs, you will need to manually update th #### Permission denied for view If you get the error `driverError: error: permission denied for view pg_vector_index_stat`, you can fix this by connecting to the Immich database and running `GRANT SELECT ON TABLE pg_vector_index_stat TO <immichdbusername>;`. + +[vectors-install]: https://docs.pgvecto.rs/getting-started/installation.html diff --git a/docs/docs/administration/system-settings.md b/docs/docs/administration/system-settings.md index 21eeaaee89..e90f49fed3 100644 --- a/docs/docs/administration/system-settings.md +++ b/docs/docs/administration/system-settings.md @@ -37,9 +37,7 @@ You can set the scanning interval using the preset or cron format. For more info ## Logging -By default logs are set to record at the log level, the network administrator can choose a deeper or lower level of logs according to his decision or according to the needs required by the Immich support team. - -Here you can [learn about the different error levels](https://sematext.com/blog/logging-levels/). +The default Immich log level is `Log` (commonly known as `Info`). The Immich administrator can choose a higher or lower log level according to personal preference or as requested by the Immich support team. ## Machine Learning Settings diff --git a/docs/docs/features/libraries.md b/docs/docs/features/libraries.md index b934abd730..628bb880c1 100644 --- a/docs/docs/features/libraries.md +++ b/docs/docs/features/libraries.md @@ -183,6 +183,6 @@ Only an admin can do this. ::: You can define a custom interval for the trigger external library rescan under Administration -> Settings -> Library. -You can set the scanning interval using the preset or cron format. For more information please refer to e.g. [Crontab Guru](https://crontab.guru/) +You can set the scanning interval using the preset or cron format. For more information you can refer to [Crontab Guru](https://crontab.guru/). <img src={require('./img/library-custom-scan-interval.png').default} width="75%" title='Set custom scan interval for external library' /> diff --git a/docs/docs/features/supported-formats.md b/docs/docs/features/supported-formats.md index a2dc56b66a..ce3736db62 100644 --- a/docs/docs/features/supported-formats.md +++ b/docs/docs/features/supported-formats.md @@ -3,7 +3,7 @@ Immich supports a number of image and video formats, the most common of which are outlined here. :::note -For the full list, you can refer to the [Immich source code](https://github.com/immich-app/immich/blob/main/server/src/utils/mime-types.ts). +For the full list, refer to the [Immich source code](https://github.com/immich-app/immich/blob/main/server/src/utils/mime-types.ts). ::: ## Image formats diff --git a/docs/docs/install/docker-compose.mdx b/docs/docs/install/docker-compose.mdx index 52259f2eb0..9045891fd8 100644 --- a/docs/docs/install/docker-compose.mdx +++ b/docs/docs/install/docker-compose.mdx @@ -67,7 +67,7 @@ docker compose up -d ``` :::info Docker version -If you get an error `unknown shorthand flag: 'd' in -d`, you are probably running the wrong Docker version. (This happens, for example, with the docker.io package in Ubuntu 22.04.3 LTS.) You can correct the problem by `apt remove`ing Ubuntu's docker.io package and installing docker and docker-compose via [Docker's official repository](https://docs.docker.com/engine/install/ubuntu/#install-using-the-repository). +If you get an error `unknown shorthand flag: 'd' in -d`, you are probably running the wrong Docker version. (This happens, for example, with the docker.io package in Ubuntu 22.04.3 LTS.) You can correct the problem by `apt remove`ing Ubuntu's docker.io package and installing docker and docker-compose via [Docker's official repository][docker-repo]. Note that the correct command really is `docker compose`, not `docker-compose`. If you try the latter on vanilla Ubuntu 22.04 it will fail in a different way: @@ -84,27 +84,31 @@ For more information on how to use the application, please refer to the [Post In ::: :::note GitHub Authentication -Downloading container images might require you to authenticate to the GitHub Container Registry ([steps here](https://docs.github.com/en/packages/working-with-a-github-packages-registry/working-with-the-container-registry#authenticating-to-the-container-registry)). +Downloading container images might require you to authenticate to the GitHub Container Registry ([steps here][container-auth]). ::: ### Step 4 - Upgrading :::danger Breaking Changes -It is important to follow breaking updates to avoid problems. You can see versions that had breaking changes [here](https://github.com/immich-app/immich/discussions?discussions_q=label%3Abreaking-change+sort%3Adate_created). +It is important to follow breaking updates to avoid problems. You can see versions that had breaking changes [here][breaking]. ::: If `IMMICH_VERSION` is set, it will need to be updated to the latest or desired version. -When a new version of Immich is [released](https://github.com/immich-app/immich/releases), the application can be upgraded with the following commands, run in the directory with the `docker-compose.yml` file: +When a new version of Immich is [released][releases], the application can be upgraded with the following commands, run in the directory with the `docker-compose.yml` file: ```bash title="Upgrade Immich" docker compose pull && docker compose up -d ``` :::caution Automatic Updates -Immich is currently under heavy development, which means you can expect [breaking changes](https://github.com/immich-app/immich/discussions?discussions_q=label%3Abreaking-change+sort%3Adate_created) and bugs. Therefore, we recommend reading the release notes prior to updating and to take special care when using automated tools like [Watchtower][watchtower]. +Immich is currently under heavy development, which means you can expect [breaking changes][breaking] and bugs. Therefore, we recommend reading the release notes prior to updating and to take special care when using automated tools like [Watchtower][watchtower]. ::: [compose-file]: https://github.com/immich-app/immich/releases/latest/download/docker-compose.yml [env-file]: https://github.com/immich-app/immich/releases/latest/download/example.env [watchtower]: https://containrrr.dev/watchtower/ +[breaking]: https://github.com/immich-app/immich/discussions?discussions_q=label%3Abreaking-change+sort%3Adate_created +[container-auth]: https://docs.github.com/en/packages/working-with-a-github-packages-registry/working-with-the-container-registry#authenticating-to-the-container-registry +[releases]: https://github.com/immich-app/immich/releases +[docker-repo]: https://docs.docker.com/engine/install/ubuntu/#install-using-the-repository diff --git a/docs/docs/install/environment-variables.md b/docs/docs/install/environment-variables.md index 6f768a0af0..dce9d4fa59 100644 --- a/docs/docs/install/environment-variables.md +++ b/docs/docs/install/environment-variables.md @@ -41,7 +41,7 @@ These environment variables are used by the `docker-compose.yml` file and do **N | `IMMICH_REVERSE_GEOCODING_ROOT` | Path of reverse geocoding dump directory | `/usr/src/resources` | microservices | :::tip -`TZ` should be set to a `TZ identifier` from [this list](https://en.wikipedia.org/wiki/List_of_tz_database_time_zones#List). For example, `TZ="Etc/UTC"`. +`TZ` should be set to a `TZ identifier` from [this list][tz-list]. For example, `TZ="Etc/UTC"`. `TZ` is only used by `exiftool`, which is present in the microservices container, as a fallback in case the timezone cannot be determined from the image metadata. ::: @@ -72,7 +72,7 @@ These environment variables are used by the `docker-compose.yml` file and do **N :::info -When `DB_URL` is defined, the other database (`DB_*`) variables are ignored. +When `DB_URL` is defined, the other database (`DB_*`) variables are ignored, with the exception of `DB_VECTOR_EXTENSION`. ::: @@ -91,7 +91,7 @@ When `DB_URL` is defined, the other database (`DB_*`) variables are ignored. :::info `REDIS_URL` must start with `ioredis://` and then include a `base64` encoded JSON string for the configuration. -More info can be found in the upstream [ioredis](https://ioredis.readthedocs.io/en/latest/API/) documentation. +More info can be found in the upstream [ioredis][redis-api] documentation. - When `REDIS_URL` is defined, the other redis (`REDIS_*`) variables are ignored. - When `REDIS_SOCKET` is defined, the other redis (`REDIS_*`) variables are ignored. @@ -159,7 +159,7 @@ Other machine learning parameters can be tuned from the admin UI. ## Docker Secrets -The following variables support the use of [Docker secrets](https://docs.docker.com/engine/swarm/secrets/) for additional security. +The following variables support the use of [Docker secrets][docker-secrets] for additional security. To use any of these, replace the regular environment variable with the equivalent `_FILE` environment variable. The value of the `_FILE` variable should be set to the path of a file containing the variable value. @@ -173,8 +173,14 @@ the `_FILE` variable should be set to the path of a file containing the variable | `DB_URL` | `DB_URL_FILE`<sup>\*1</sup> | | `REDIS_PASSWORD` | `REDIS_PASSWORD_FILE`<sup>\*2</sup> | -\*1: See the [official documentation](https://github.com/docker-library/docs/tree/master/postgres#docker-secrets) for +\*1: See the [official documentation][docker-secrets-docs] for details on how to use Docker Secrets in the Postgres image. -\*2: See [this comment](https://github.com/docker-library/redis/issues/46#issuecomment-335326234) for an example of how +\*2: See [this comment][docker-secrets-example] for an example of how to use use a Docker secret for the password in the Redis container. + +[tz-list]: https://en.wikipedia.org/wiki/List_of_tz_database_time_zones#List +[docker-secrets-example]: https://github.com/docker-library/redis/issues/46#issuecomment-335326234 +[docker-secrets-docs]: https://github.com/docker-library/docs/tree/master/postgres#docker-secrets +[docker-secrets]: https://docs.docker.com/engine/swarm/secrets/ +[redis-api]: https://docs.docker.com/engine/install/ubuntu/#install-using-the-repository diff --git a/docs/docs/install/kubernetes.md b/docs/docs/install/kubernetes.md index 57db569128..d66f6193d1 100644 --- a/docs/docs/install/kubernetes.md +++ b/docs/docs/install/kubernetes.md @@ -6,7 +6,7 @@ sidebar_position: 40 You can deploy Immich on Kubernetes using [the official Helm chart](https://github.com/immich-app/immich-charts/tree/main/charts/immich). -If you want examples of how other people run Immich on Kubernetes, using the official chart or otherwise, you can find them at https://nanne.dev/k8s-at-home-search/#/immich. +You can view some [examples](https://kubesearch.dev/#/immich) of how other people run Immich on Kubernetes, using the official chart or otherwise. :::caution DNS in Alpine containers Immich makes use of Alpine container images. These can encounter [a DNS resolution bug](https://stackoverflow.com/a/65593511) on Kubernetes clusters if the host