手机照片备份方案Immich

article/2025/8/22 22:06:10

在这里插入图片描述

周六继续

在这里插入图片描述


什么是 Immich ?

Immich 是直接从您的手机上自行托管照片和视频的备份解决方案。目前这个项目正在大力开发中,将会有持续的功能、特性和 api 变化,所以暂时不要用在生产环境。

在这里插入图片描述

Immich 是老苏 6 月中旬折腾的,不知道参数、接口是否已经有变化?往常在发布前都会再次验证,但最近没时间,有问题请留言。

命令行安装

Immich 项目用到了比较多的服务:

    1. NestJs - 应用程序的后端
    1. SvelteKit - 应用程序的 Web 前端
    1. PostgreSQL - 应用程序的主数据库
    1. Redis - 用于在 docker 实例和后台任务消息队列之间共享 websocket 实例。
    1. Nginx - 负载均衡和优化的文件上传。
    1. TensorFlow - 对象检测和图像分类。

所以直接采用 docker compose 来安装、测试,而不是用图形界面的群晖 docker 管理器。

准备工作

从老苏的 github 下载 immich.zip 文件,地址:https://github.com/wbsu2003/synology/raw/main/immich/immich.zip

当然直接用官方的可能更好,https://github.com/immich-app/immich/tree/main/docker

将其解压到 docker 目录,最终像👇这样就对了

注意不要在 PC 上解压,因为 .env 文件会被识别为系统文件,默认会自动隐藏,导致复制时遗漏掉

在这里插入图片描述

设置 .env 文件

# 数据库
DB_USERNAME=postgres
DB_PASSWORD=postgres
DB_DATABASE_NAME=immich
DB_LOCATION=./data# Redis
REDIS_HOSTNAME=immich_redis# 上传文件配置
UPLOAD_LOCATION=./upload#JWT SECRET
JWT_SECRET=RdjXLHfm3gTcqWq7z6GBwtyipvuHMBMiZ2VygWLVRCBdWdSBgP9jSEk5E9Y8Xhhy# MAPBOX
## ENABLE_MAPBOX -> 如果为真,则必须提供 MAPBOX_KEY
ENABLE_MAPBOX=false
MAPBOX_KEY=# 网页地址
VITE_SERVER_ENDPOINT=http://192.168.0.197:2383

关于参数简单说明一下:

如果只是局域网使用或者简单测试一下,数据库部分可以不改,如果要在互联网上使用,觉得不够安全,可以不对外映射数据库的端口,来阻止从外部访问数据库,当然你也可以设置更复杂的密码,来增加被破解的难度

  • DB_USERNAME:数据库用户;

  • DB_PASSWORD:数据库密码,建议设置的复杂一点;

  • DB_DATABASE_NAME:数据库库名,默认的就可以了;

  • DB_LOCATION:数据库存储目录,指向 immich 中的子目录 data

  • REDIS_HOSTNAME:默认就可以了;

  • UPLOAD_LOCATION:这是上传目录,指向 immich 中的子目录 upload

  • JWT_SECRET:一串随机字符串,要求长且强大,最好无人能猜,老苏是用 bitwarden 密码生成器的;

  • ENABLE_MAPBOX:默认设为 false,如果你要改为 true,需要去 https://www.mapbox.com/ 注册账号,申请 API Key

注册 mapbox 需要验证信用卡

  • MAPBOX_KEY:如果 ENABLE_MAPBOX=true,这里必须填在上一步申请的 API Key,否则请留空;

  • VITE_SERVER_ENDPOINT:填反代后的域名或者群晖 IP + 端口;

粗看了一下,现在地址后面似乎要加上 /api

docker-compose.yml

docker-compose.yml 在官方的基础上做了必要的微调,除了端口其他可以不动

version: "3.8"services:immich-server:image: altran1502/immich-server:latestentrypoint: ["/bin/sh", "./start-server.sh"]expose:- "3000"volumes:- ${UPLOAD_LOCATION}:/usr/src/app/uploadenv_file:- .envenvironment:- NODE_ENV=productiondepends_on:- redis- databasenetworks:- immich-networkrestart: alwaysimmich-microservices:image: altran1502/immich-server:latestentrypoint: ["/bin/sh", "./start-microservices.sh"]volumes:- ${UPLOAD_LOCATION}:/usr/src/app/uploadenv_file:- .envenvironment:- NODE_ENV=productiondepends_on:- redis- databasenetworks:- immich-networkrestart: alwaysimmich-machine-learning:image: altran1502/immich-machine-learning:latestentrypoint: ["/bin/sh", "./entrypoint.sh"]expose:- "3001"volumes:- ${UPLOAD_LOCATION}:/usr/src/app/uploadenv_file:- .envenvironment:- NODE_ENV=productiondepends_on:- databasenetworks:- immich-networkrestart: alwaysimmich-web:image: altran1502/immich-web:latestentrypoint: ["/bin/sh", "./entrypoint.sh"]env_file:- .envports:- 2385:3000networks:- immich-networkrestart: alwaysredis:container_name: immich_redisimage: redis:6.2networks:- immich-networkrestart: alwaysdatabase:container_name: immich_postgresimage: postgres:14env_file:- .envenvironment:POSTGRES_PASSWORD: ${DB_PASSWORD}POSTGRES_USER: ${DB_USERNAME}POSTGRES_DB: ${DB_DATABASE_NAME}PG_DATA: /var/lib/postgresql/datavolumes:- ${DB_LOCATION}:/var/lib/postgresql/dataports:- 5440:5432networks:- immich-networkrestart: alwaysnginx:container_name: proxy_nginximage: nginx:latestvolumes:- ./settings/nginx-conf:/etc/nginx/conf.dports:- 2383:80- 2384:443logging:driver: nonenetworks:- immich-networkdepends_on:- immich-serverrestart: alwaysnetworks:immich-network:

启动服务器

开始运行

# 进入 immich 目录
cd /volume2/docker/immich# 一键启动
docker-compose up -d# 一键启动(官方推荐的模式,带日志显示)
docker-compose -f ./docker-compose.yml up

在这里插入图片描述

如果是带日志的模式,看到

LOG [IMMICH MICROSERVICES] Running Immich Machine Learning in PRODUCTION environment

表示 TensorFlow 已重建成功

一共有 7 个容器

在这里插入图片描述

在这里插入图片描述

运行

初始化的过程有点长,要等一段时间再在浏览器中输入 http://群晖IP:2385 才能看到主界面

比较意外,第一次运行居然提示有新版本

在这里插入图片描述

Getting Started 按钮继续

在这里插入图片描述

先要创建管理员账号

然后需要登录

在这里插入图片描述

登录成功后的主界面,从左下角可以看到当前的版本是 v1.11.0

在这里插入图片描述

其他用户需要管理员创建

移动端下载

Android 端的应用可以在 F-Droid 下载:https://f-droid.org/packages/app.alextran.immich/

当然你也可以在 Google Play 商店 里下载

在这里插入图片描述

iOS 只能去 Apple AppStore

在这里插入图片描述

Android

老苏只有 Android手机,所以以 Android 为例

安装成功后需要登录,相比网页版,多了一项服务器地址

服务器地址就是 .envVITE_SERVER_ENDPOINT 中设定的地址,也可以在网页版的左下角找到

在这里插入图片描述

主界面开始是空的,点右上角图标进入备份界面

在这里插入图片描述

选择好要备份的相册,然后点最下面的 Start Backup 开始备份

在这里插入图片描述

开始备份后,刷新网页可以看到已经备份的图片

在这里插入图片描述

点开图片,功能比较简单,除了下载就是图片信息

在这里插入图片描述

最后来一张官网的动图,据说加载了 4000 图片/视频,看起来还是很顺滑的

在这里插入图片描述

参考文档

alextran1502/immich: Self-hosted photo and video backup solution directly from your mobile phone.
地址:https://github.com/alextran1502/immich

Immich - Self-hosted backup photos/videos from your mobile phone (kinda Google Photos replacement) - Progress update May, 22nd 2022. Now with the web interface to view backup assets and user management. : selfhosted
地址:https://www.reddit.com/r/selfhosted/comments/uvlvmm/immich_selfhosted_backup_photosvideos_from_your/


http://chatgpt.dhexx.cn/article/fCJw6wNx.shtml

相关文章

android备份手机号码,简单四步 完成Android手机通讯录云备份操作

近两年,智能手机开始普及,一些发烧友甚至左手一个Android右手一个iPhone,兜里可能还有一个能砸核桃的诺基亚(塞班)。手机多了,多年累积的电话号码不能互通就成了“老大难”问题,去手机店导数据要花上几十上百元&#x…

华为手机备份的通讯录是什么文件_手机怎么备份通讯录?华为手机备份方法大全...

原标题:手机怎么备份通讯录?华为手机备份方法大全 现在有很多人选择国产手机,而华为手机作为国产手机中的佼佼者,使用的人也有很多,今天我们就来聊聊会为手机里的备份。 1、本地备份 华为手机中自带有备份的功能&#…

android 手机数据备份,怎么备份手机数据 手机数据备份方法介绍

‍如果你是一个喜欢刷机的机友,如果你是个经常换手机的主儿,那么备份手机数据是十分必要的一个步骤。就拿刷机来说吧,刷机中会将手机上的资料和文件全部清理,所以在刷机前做好备份是非常重要的,手机中重要的通讯录、短…

360 android手机备份通讯录,360手机卫士怎样备份手机通讯录 备份手机通讯录图文教程...

软件安装:手机应用宝 随着科技的发展,手机在我们的生活中扮演了很重要的角色,手机在便利我们生活的同时,也会对我们造成很重要的影响.手机已经成为了我们的必需品,不仅是通讯工具,而且很大程度上都是娱乐功…

android 手机如何备份通讯录,手机通讯录怎么备份

如今手机已经是智能时代了,各项手机功能相对都是十分齐全。但很多朋友会经常出现手机丢失、被盗或者换手机的情况,为了避免手机通讯录也因此丢失,怎么才能把手机通讯录导出进行备份呢?有没有一种方法,可以让我们永不丢失手机通讯录呢?答案是肯定的&…

手机助手无法启动备份服务器,华为手机助手备份数据无法恢复怎么办?华为手机助手备份数据无法恢复教程...

相信很多华为手机用户,都有开通手机云备份这一功能,让手机上的数据定期自动备份,以免自己在使用过程中,不小心误删了重要数据。可是,有些用户反映自己利用华为手机助手备份的数据无法恢复。 那么,出现这样的…

国外的TPM和国内的TCM安全芯片

转自:http://safe.it168.com/a2012/0912/1396/000001396884.shtml 【IT168 专稿】从2003年开始,重要数据丢失已经成为严重的信息安全问题。尽管企业、机构和个人均不同程度地部署了保密措施,但泄密案例还是层出不穷。从近年来国内外公开发布…

交错TCM图腾柱无桥PFC仿真

TCM图腾柱即临界模式图腾柱,也叫CRM图腾柱或BCM图腾柱。 与交错CRM BOOST PFC一样,本仿真同样使用电压模式恒导通时间控制,其仿真可分为功率电路、COT与环路控制、过零检测与起振信号、变频交错控制,详见: 交错CRM BO…

开源开放 | 中药说明书实体识别数据集TCM-NER

OpenKG地址:http://openkg.cn/dataset/tcm-ner 阿里云天池:https://tianchi.aliyun.com/dataset/dataDetail?dataId86819 开放许可协议:CC BY-SA 4.0 (署名相似共享) 贡献者:阿里云(陈漠沙&…

tcm_fc自动加载 linux,[Fibre Channle 实战之四]centos7中如何添加tcm_qla2xxx支持

centos7中自带的有qla2xxx驱动,但是没有tcm_qla2xxx驱动,这会创建一些HBA卡的target的时候失败。为此,需要保证tcm_qla2xxx.ko驱动能生成并自动执行。那么该如何解决这个问题呢? 1.选择tcm_qla2xxx模块 首先,进入和当前centos内核…

看见“信任”,可信计算平台的由来解读(TPM、TCM、TPCM、等保2.0解读)。

可信计算平台由来解读 一、关键名词二、什么是可信计算TPM、TCM、TPCM由来 三、等保2.0关于可信要求的解读四、阿里云可信计算实践五、结语 一、关键名词 TPM(Trusted Platform Module)可信平台模块,是一种植于计算机内部为计算机提供可信根…

tcm工具 软件测试,tcm:向测试用例中导入自动测试

tcm:向测试用例中导入自动测试 02/21/2013 本文内容 您可以将自动测试(例如,单元测试或编码 UI 测试)导入测试项目,用作测试计划的一部分。使用以下 tcm 命令从测试程序集导入测试: tcm testcase /import 您基于提供的参数选择的每…

SOC存储系统 CACHE TCM OCM

CPU CACHE CPU缓存的定义为CPU与内存之间的临时数据交换器,它的出现是为了解决CPU运行处理速度与内存读写速度不匹配的矛盾——缓存的速度比内存的速度快多了。CPU缓存一般直接跟CPU芯片集成或位于主板总线互连的独立芯片上。(现阶段的CPU缓存一般直接集…

tcm可信密码模块linux,一种基于国产TCM芯片的可信冗余密码服务器的制作方法

本发明涉及国产飞腾计算机、数据加解密以及身份验证等技术领域,特别涉及一种基于国产TCM芯片的可信冗余密码服务器。 背景技术: TCM芯片,是由国家密码管理局联合国内一些IT企业推出的。它是一种安全芯片,能有效保护PC,…

tcm_fc自动加载 linux,升腾TCM(CCCM)5.6版本Linux安装指导

升腾TCM(CCCM)5.6版本Linux安装指导 1.概述 升腾提供的TCM自5.6版本往后,在继续支持Windows安装的基础上,新增支持在Linux操作系统上进行安装。 在目前已经发布的版本中,Linux操作系统版本的TCM跟Windows版本的TCM对外提供功能完全一样&#…

tcm可信密码模块linux,一种基于国产TCM芯片的可信密码模块及其工作方法与流程...

本发明涉及一种基于国产TCM芯片的可信密码模块及其工作方法,涉及国产计算平台安全可信、自主可控、数据加解密、安全审计、完整性保护等,属于计算机平台设计技术领域。 背景技术: 随着信息电子化与信息全球化的飞速发展,人们对计算机在工作、生活中的选择与侧重逐渐从使用属…

tcm工具 软件测试,如何使用 TCM? TCM 测试总结报告

1.究竟什么是TCM? TCM(ThunderboltCertificaTIonManager)是一套由Intel研发之几近全自动化的测试工具,且为Thunderbolt™认证测试中必要使用之工具。TCM能够针对Thunderbolt™4FuncTIonalCTS(ComplianceTestSpecificaTIon)的各项测试项目,进行Thunderbolt™4Host或者Thunder…

ThinkPHP缓存文件写入失败

情况:Windows下网站直接拷贝至Ubuntu 1.删除cache下的所有临时文件。(需保留Thinkphp Runtime下的文件结构,删除文件内容) 2.提权,在Linux命令行输入 sudo chmod 777 -R /var/www 转载于:https://www.cnblogs.com/vale…

Redis查询缓存

文章目录 缓存更新策略主动更新策略问题考虑 难题1.缓存穿透解决方案: 2.缓存击穿互斥锁逻辑过期 3.缓存雪崩 商品查询缓存实例解决缓存穿透解决缓存击穿互斥锁(这里还要考虑了缓存穿透问题)逻辑时间 缓存更新策略 内存淘汰超时剔除主动更新…

redis的成功写入缓存但查不了

最近在学习redis的简单应用并写出实例结果出现了一个非常奇怪的问题,每次查询都是从mysql中读入并且写入缓存成功但当我再次查询时仍然是从MySQL中读取数据并且再次写入缓存 这让我十分疑惑,实际上就是因为我#spring.redis.database1这行代码没有写但我…