Immich v1.102.0 - ⚠️ Breaking Changes (OPT-IN ONLY)
Immich v1.102.0 - ⚠️ Breaking Changes (OPT-IN ONLY)

v1.102.0 - 30,000 Stars Release 🌟 · immich-app immich · Discussion #8930

Immich v1.102.0 - ⚠️ Breaking Changes (OPT-IN ONLY)
v1.102.0 - 30,000 Stars Release 🌟 · immich-app immich · Discussion #8930
Who the hell is pulling the docker-compise.yml automatically every release? I find myself already crazy by pulling the latest release but the compose file is just a disaster waiting to happen.
I honestly never once thought to do this. Ever. No likey.
Especially since the original doesn't care about selinux and it would overwrite everything.
And it doesn't specify a repository which breaks auto updates of podman
Complete insanity.
Then again it seems like people were using a docker volume to save all their precious photos rather than a mount point on the host. Also seems insane to me.
Could you explain a bit more about why it's insane to have it as a docked volume instead of a mount point on the host? I'm not too well-versed with docker (or maybe hosting in general)
Edit: typo
What's the difference? The docker volume, on my setup anyway, is in /mnt/md0/docker-data/immich_upload/_data/
It's still a directory on the host either way? Although I guess if it's a mount point it won't get removed when removing volumes in docker.
I mounted that volume the first time I opened immich's compose file, glad they changed it =)
lol same I like to know exactly where the data is
Me too!
- /opt/immich/postgres:/var/lib/postgresql/data
Exactly this, my docker host has a folder for docker data. In there are sub folders for each docker app. Borg back grabs the entire docker data folder and backs it up.
If there are any issues, I can easily see all the files.
I have no idea how people trust things like docker volumes with valuable data without the ability to just see into the filesystem easily.
I’m not using immich in docker. Can you explain what this breaking is there to fix?
The datbase files were saved in an internal docker directory and the breaking change is that the location is now different, outside of docker.
Didn't know it, so from readme: Immich, a high performance self-hosted photo and video management solution.
I was surprised to see the default compose file not force the user to specify an external directory for the database.
Who was pulling the dicker compose and just straight up running the GitHub version on their server. That seems crazy. Even pulling :latest tag seems crazy to me but this is another level.
This change is only breaking if you are running someone else's docker compose on your server without looking at it.
Also who was running their entire photo album in a docker volume rather than a mount point on the host. Another insane decision. To be fair, the default docker compose never should have had that. It should have been a mount point right from the start.
I don’t run Immich specifically but all other software I run is on :latest tags and unattended-upgrades on Debian. It works so, why bother?
Just did the upgrade. Only went and copied the docker folder for the volume.
# docker inspect immich_pgdata | jq -r ".[0].Mountpoint" /var/lib/docker/volumes/immich_pgdata/_data
Inside that folder were all the DB files, so I just copied that into the new folder I created for ./postgres
I thought there would be issues with the file permissions, but not, everything went smoothly and I can't see any data loss.
(This even was a migration from 1.94 to 1.102, so I also did the pgvecto-rs upgrade)
Me, an intellectual, who was already mounting the database data folder to the host filesystem.
First time im not completely sure how to proceed with update. This part is unclear to me:
Unfortunately there isn't a "proper" way to export a docker volume. The recommended method is to mount the volume and the directory (you want to copy your data to) to an arbitrary container, get a shell inside that container and copy the folder manually.
I know how to stop the container and dump db, but need some help here
Just go to /var/lib/docker/volumes and copy the data out of the relevant volume. No need to mount anything.
I went about it this way as well, was much easier this way.
Thx ill give it a try
Pretty simple to switch (if you have a little docker experience). Create a folder (e.g. ./postgres
), add the folder as a volume in the postgres portion of the compose file (maybe something like /db
), then run just the database with newly mounted folder, shell in, and copy everything from the Postgres folder to this new folder. After that, swap mounts so the new folder is used as Postgres db and you’re good. If something went wrong, the pgdata
volume is still there to switch back to.
I really wish they get to the point where we can expect long term with no breaking changes. I love it but I have been burnt twice, which is not a lot, but it was very annoying both times
Who is out there running compose down -v
when they want to keep their data lol
Not a fan of this change, using volumes is what makes docker truly portable between systems. It's not the responsibility of Immich if people are running the wrong commands when managing their system.