手机照片备份方案Immich

在这里插入图片描述

周六继续

在这里插入图片描述


什么是 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:latest
    entrypoint: ["/bin/sh", "./start-server.sh"]
    expose:
      - "3000"
    volumes:
      - ${UPLOAD_LOCATION}:/usr/src/app/upload
    env_file:
      - .env
    environment:
      - NODE_ENV=production
    depends_on:
      - redis
      - database
    networks:
      - immich-network
    restart: always

  immich-microservices:
    image: altran1502/immich-server:latest
    entrypoint: ["/bin/sh", "./start-microservices.sh"]
    volumes:
      - ${UPLOAD_LOCATION}:/usr/src/app/upload
    env_file:
      - .env
    environment:
      - NODE_ENV=production
    depends_on:
      - redis
      - database
    networks:
      - immich-network
    restart: always

  immich-machine-learning:
    image: altran1502/immich-machine-learning:latest
    entrypoint: ["/bin/sh", "./entrypoint.sh"]
    expose:
      - "3001"
    volumes:
      - ${UPLOAD_LOCATION}:/usr/src/app/upload
    env_file:
      - .env
    environment:
      - NODE_ENV=production
    depends_on:
      - database
    networks:
      - immich-network
    restart: always

  immich-web:
    image: altran1502/immich-web:latest
    entrypoint: ["/bin/sh", "./entrypoint.sh"]
    env_file:
      - .env
    ports:
      - 2385:3000
    networks:
      - immich-network
    restart: always

  redis:
    container_name: immich_redis
    image: redis:6.2
    networks:
      - immich-network
    restart: always

  database:
    container_name: immich_postgres
    image: postgres:14
    env_file:
      - .env
    environment:
      POSTGRES_PASSWORD: ${DB_PASSWORD}
      POSTGRES_USER: ${DB_USERNAME}
      POSTGRES_DB: ${DB_DATABASE_NAME}
      PG_DATA: /var/lib/postgresql/data
    volumes:
      - ${DB_LOCATION}:/var/lib/postgresql/data
    ports:
      - 5440:5432
    networks:
      - immich-network
    restart: always

  nginx:
    container_name: proxy_nginx
    image: nginx:latest
    volumes:
      - ./settings/nginx-conf:/etc/nginx/conf.d
    ports:
      - 2383:80
      - 2384:443
    logging:
      driver: none
    networks:
      - immich-network
    depends_on:
      - immich-server
    restart: always

networks:
  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/

xbackup提供了多种备份方案和脚本,用户可以根据自己的需求进行选择和配置。以下是一些xbackup备份方案和脚本的介绍: 1. 完全备份方案 完全备份方案是最简单和最直接的备份方式,它会备份整个数据集。可以使用以下脚本进行完全备份: ``` xbackup full /path/to/backup ``` 2. 增量备份方案 增量备份方案备份最近一次完全备份之后的更改。这种备份方式可以减少备份所需的时间和存储空间。可以使用以下脚本进行增量备份: ``` xbackup incremental /path/to/backup ``` 3. 差异备份方案 差异备份方案备份最近一次备份之后的更改,而不是备份整个数据集。与增量备份相比,它可以减少备份所需的时间和存储空间,但恢复数据时可能需要更长的时间。可以使用以下脚本进行差异备份: ``` xbackup differential /path/to/backup ``` 4. 本地备份方案 本地备份方案备份文件存储在本地磁盘上。可以使用以下脚本进行本地备份: ``` xbackup full /path/to/backup --target local:/path/to/backup/dir ``` 5. 远程备份方案 远程备份方案备份文件传输到远程服务器上。可以使用以下脚本进行远程备份: ``` xbackup full /path/to/backup --target ssh://user@remote:/path/to/backup/dir ``` 6. 云备份方案备份方案备份文件存储在云存储服务上,例如Amazon S3,Google Cloud Storage或Microsoft Azure。可以使用以下脚本进行云备份: ``` xbackup full /path/to/backup --target s3://bucket-name/path/to/backup/dir ``` 以上是一些常见的xbackup备份方案和脚本,用户可以根据自己的需求进行选择和配置。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

杨浦老苏

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值