数字时代的记忆保管箱Shoebox

简介

什么是 Shoebox ?

Shoebox 是一个数字解决方案,旨在组织和保存视频,模拟过去人们用实体鞋盒保存珍贵记忆的方式。它为用户提供了一个专门的空间,以避免视频在云服务或社交媒体平台中丢失。

主要特点

  1. 视频组织:能够有效地组织用户的视频,便于未来的回顾和使用。
  2. 视频导出功能:支持将原始视频导出到指定位置,方便导入到视频编辑器中进行后续处理。
  3. 记忆保存:以结构化的方式保存视频记忆,使其易于访问并可用于未来的创意项目。
  4. 用户友好的界面:提供简单易用的界面,方便用户进行视频管理。
  5. 高效的媒体处理 :使用 FFmpeg 进行视频处理,确保操作的高效性和准确性。
  6. 技术栈 :后端使用 RustAxum,前端基于 ReactTypeScript,支持 SQLite/PostgreSQL 数据库,并具备 Docker/Kubernetes 部署能力。

应用场景

  • 家庭视频管理:适合家庭用户保存和组织孩子成长过程中的视频,方便随时回顾。
  • 创意项目:为视频创作者提供一个结构化的存储解决方案,便于未来制作高光集或拼贴。
  • 教育记录 :教育工作者可以使用 Shoebox 保存教学视频,以便于未来的教学参考。

Shoebox 通过提供安全、方便的视频管理解决方案,帮助用户有效地保存和利用数字记忆。

安装

在群晖上以 Docker 方式安装。

本文写作时, latest 版本对应为 sha-9f05da53931ad6fa4f5b7f1d9b447ca65dec3e8b

docker cli 安装

如果你熟悉命令行,可能用 docker cli 更快捷

bash 复制代码
# 新建文件夹 shoebox 和 子目录
mkdir -p /volume1/docker/shoebox/{data,exports,thumbnails,videos}

# 进入 shoebox 目录
cd /volume1/docker/shoebox

# 运行容器
docker run -d \
  --name shoebox \
  --restart unless-stopped \
  -p 3823:3000 \
  -v $(pwd)/videos:/mnt/videos:ro \
  -v $(pwd)/exports:/app/exports \
  -v $(pwd)/data:/app/data \
  -v $(pwd)/thumbnails:/app/thumbnails \
  -e SERVER_HOST=0.0.0.0 \
  -e SERVER_PORT=3000 \
  -e DATABASE_URL=sqlite:/app/data/videos.db \
  -e MEDIA_SOURCE_PATHS=/mnt/videos \
  -e THUMBNAIL_PATH=/app/thumbnails \
  -e EXPORT_BASE_PATH=/app/exports \
  -e RUST_LOG=info \
  ghcr.io/slackspace-io/shoebox:latest
  • 映射路径的说明
文件夹 装载路径 说明
docker/shoebox/videos /mnt/videos 存放视频文件
docker/shoebox/exports /app/exports 存放导出内容
docker/shoebox/data /app/data 存放数据库文件
docker/shoebox/thumbnails /app/thumbnails 存放缩略图文件
  • 环境变量的说明
可变
SERVER_HOST 用于绑定服务器的主机,缺省值为 127.0.0.1
SERVER_PORT 用于绑定服务器的端口,缺省值为 3000
DATABASE_URL 数据库连接 URL,支持 SQLite/PostgreSQL
MEDIA_SOURCE_PATHS 扫描视频的路径,可以指定一个或多个路径,以逗号分隔
THUMBNAIL_PATH 存储缩略图的路径
EXPORT_BASE_PATH 导出文件的路径
RUST_LOG 日志级别

docker-compose 安装

也可以用 docker-compose 安装,将下面的内容保存为 docker-compose.yml 文件

yaml 复制代码
version: '3.8'

services:
  app:
    image: ghcr.io/slackspace-io/shoebox:latest
    container_name: shoebox
    restart: unless-stopped
    ports:
      - "3823:3000"
    volumes:
      # Mount media source directories (read-only)
      - ./videos:/mnt/videos:ro
      # Mount export directory (read-write)
      - ./exports:/app/exports
      # Mount data directory for persistence
      - ./data:/app/data
      # Mount thumbnails directory for persistence
      - ./thumbnails:/app/thumbnails
    environment:
      - SERVER_HOST=0.0.0.0
      - SERVER_PORT=3000
      - DATABASE_URL=sqlite:/app/data/videos.db
      - MEDIA_SOURCE_PATHS=/mnt/videos
      - THUMBNAIL_PATH=/app/thumbnails
      - EXPORT_BASE_PATH=/app/exports
      - RUST_LOG=info   

然后执行下面的命令

bash 复制代码
# 新建文件夹 shoebox 和 子目录
mkdir -p /volume1/docker/shoebox/{data,exports,thumbnails,videos}

# 进入 shoebox 目录
cd /volume1/docker/shoebox

# 将 docker-compose.yml 放入当前目录

# 一键启动
docker-compose up -d

运行

在浏览器中输入 http://群晖IP:3823 就能看到主界面

videos 目录中放入视频文件

Scan Directories 扫描视频目录

开始扫描

扫描完成后

进入视频详情

参考文档

slackspace-io/shoebox

地址:https://github.com/slackspace-io/shoebox
Introduction - Shoebox Docs

地址:https://slackspace-io.github.io/shoebox/
Demo of shoebox - YouTube

地址:https://www.youtube.com/watch?v=xfPMCLWnUz8