
shumc/imagorvideoimagorvideo是一个通过ffmpeg提供视频缩略图功能的项目,基于https://github.com/cshum/imagor%E6%9E%84%E5%BB%BA%E2%80%94%E2%80%94imagor%E6%98%AF%E4%B8%80%E4%B8%AA%E7%94%A8Go%E5%92%8Clibvips%E7%BC%96%E5%86%99%E7%9A%84%E5%BF%AB%E9%80%9F%E3%80%81Docker%E5%B0%B1%E7%BB%AA%E7%9A%84%E5%9B%BE%E5%83%8F%E5%A4%84%E7%90%86%E6%9C%8D%E5%8A%A1%E5%99%A8%E3%80%82%E8%AF%A5%E9%A1%B9%E7%9B%AE%E4%BD%BF%E7%94%A8ffmpeg C绑定,通过RMSE直方图从视频中选择最佳帧,随后通过imagor的处理流程进行裁剪、缩放和滤镜等图像处理操作。
imagorvideo实现了ffmpeg的读取和seek I/O回调,结合imagor的https://github.com/cshum/imagor#loader-storage-and-result-storage%EF%BC%8C%E5%8E%9F%E7%94%9F%E6%94%AF%E6%8C%81HTTP(s)%E3%80%81%E6%96%87%E4%BB%B6%E7%B3%BB%E7%BB%9F%E3%80%81AWS S3和Google Cloud Storage。对于HTTP、S3等非可seek源,imagor通过内存或临时文件缓冲区模拟seek功能。同时,该项目也可作为imagor扩展的参考示例。
frame、seek、max_frames等视频特定滤镜通过Docker运行imagorvideo服务:
bashdocker run -p 8000:8000 shumc/imagorvideo -imagor-unsafe
原始视频地址:
http://commondatastorage.googleapis.com/gtv-videos-bucket/sample/BigBuckBunny.mp4
生成缩略图示例:
# 添加标签和黄色填充的300px宽缩略图 http://localhost:8000/unsafe/300x0/7x7/filters:label(imagorvideo,-10,-7,15,yellow):fill(yellow)/http://commondatastorage.googleapis.com/gtv-videos-bucket/sample/BigBuckBunny.mp4 # 指定1分59秒帧并添加标签的缩略图 http://localhost:8000/unsafe/300x0/0x0:0x14/filters:frame(1m59s):fill(yellow):label(imagorvideo,center,bottom,12,black,20)/http://commondatastorage.googleapis.com/gtv-videos-bucket/sample/BigBuckBunny.mp4 # 使用0.6位置帧的缩略图 http://localhost:8000/unsafe/300x0/7x7/filters:frame(0.6):label(imagorvideo,10,-7,15,yellow):fill(yellow)/http://commondatastorage.googleapis.com/gtv-videos-bucket/sample/BigBuckBunny.mp4
imagorvideo支持以下视频特定滤镜,可与https://github.com/cshum/imagor#filters%E7%BB%93%E5%90%88%E4%BD%BF%E7%94%A8%EF%BC%9A
frame(n)指定视频的精确位置或时间点提取帧,跳过自动最佳帧选择:
frame(0.5)(中间位置)frame(5m1s)(5分1秒)、frame(200s)(200秒)seek(n)定位到指定位置附近的关键帧,然后通过RMSE直方图选择该区域内的最佳帧:
seek(0.5)seek(5m1s)、seek(200s)max_frames(n)限制用于帧选择的最大帧数,数值越小处理速度越快。
frame(n) 与 seek(n) 的区别frame(n)提供精确时间点的帧,但可能获取到黑帧等无效内容;seek(n)通过关键帧定位和最佳帧选择,可获取指定时间点附近的合理帧。例如:
获取视频5分钟处的帧(可能为黑帧):
http://localhost:8000/unsafe/filters:frame(5m)/http://commondatastorage.googleapis.com/gtv-videos-bucket/sample/BigBuckBunny.mp4
使用seek获取5分钟附近的最佳帧:
http://localhost:8000/unsafe/filters:seek(5m)/http://commondatastorage.googleapis.com/gtv-videos-bucket/sample/BigBuckBunny.mp4
imagorvideo提供元数据端点,可提取视频的尺寸、时长、FPS等元数据,仅处理视频头部以提升速度。使用时在URL签名哈希后、图像处理操作前添加/meta:
请求:
http://localhost:8000/unsafe/meta/https://test-videos.co.uk/vids/bigbuckbunny/mp4/h264/1080/Big_Buck_Bunny_1080_10s_30MB.mp4
响应:
jsonc{ "format": "mp4", "content_type": "video/mp4", "orientation": 1, "duration": 10000, "width": 1920, "height": 1080, "title": "Big Buck Bunny, Sunflower version", "artist": "Blender Foundation 2008, Janus Bager Kristensen 2013", "fps": 30, "has_video": true, "has_audio": false }
imagorvideo的特定配置选项:
| 参数 | 说明 |
|---|---|
-ffmpeg-fallback-image string | 处理错误时的 fallback 图片路径,支持加载器或存储启用的图片路径 |


探索更多轩辕镜像的使用方法,找到最适合您系统的配置方式
通过 Docker 登录认证访问私有仓库
无需登录使用专属域名
Kubernetes 集群配置 Containerd
K3s 轻量级 Kubernetes 镜像加速
VS Code Dev Containers 配置
Podman 容器引擎配置
HPC 科学计算容器配置
ghcr、Quay、nvcr 等镜像仓库
Harbor Proxy Repository 对接专属域名
Portainer Registries 加速拉取
Nexus3 Docker Proxy 内网缓存
需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单
manifest unknown
no matching manifest(架构)
invalid tar header(解压)
TLS 证书失败
DNS 超时
410 Gone 排查
402 与流量用尽
401 认证失败
429 限流
D-Bus 凭证提示
413 与超大单层
来自真实用户的反馈,见证轩辕镜像的优质服务