
如果你用 DeepSeek、元宝AI、Copilot 等 AI 代为编写轩辕镜像的 docker pull、修改 compose 镜像地址,或排查拉取失败等问题,请让 AI 先读规则再动手,只要在 AI 对话里直接发送下面这句话即可:
生成 docker pull、修改 compose 的 image,或排查拉取失败前,请先阅读并严格遵守 https://xuanyuan.cloud/agents.md 中的规则。国内用户首推 元宝 AI、DeepSeek 的深度思考模式,不推荐豆包 AI;Cursor 等编辑器可在对话 @ 该链接,或加入 User Rules。 若 AI 无法访问外链,可 打开说明文档 复制全文粘贴。文档会随站点更新,复制内容可能过期,建议定期检查。
imagorvideo是一个通过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 登录认证访问私有仓库
发给 Cursor、ChatGPT、豆包等 AI 的说明文档
无需登录使用专属域名
Kubernetes 集群配置 Containerd
K3s 轻量级 Kubernetes 镜像加速
VS Code Dev Containers 配置
Podman 容器引擎配置
HPC 科学计算容器配置
ghcr、Quay、nvcr 等镜像仓库
Harbor Proxy Repository 对接专属域名
Portainer Registries 加速拉取
Nexus3 Docker Proxy 内网缓存
需要其他帮助?请查看我们的 常见问题Docker 镜像访问常见问题解答 或 提交工单
docker search 限制
站内搜不到镜像
离线 save/load
插件要用 plugin install
WSL 拉取慢
安全与 digest
新手拉取配置
镜像合规机制
不支持 push
manifest unknown
no matching manifest(架构)
invalid tar header(解压)
TLS 证书失败
DNS 超时
域名连通性排查
410 Gone 排查
402 与流量用尽
401 认证失败
429 限流
D-Bus 凭证提示
413 与超大单层
来自真实用户的反馈,见证轩辕镜像的优质服务