首页
/ FFmpeg-over-IP 项目使用教程

FFmpeg-over-IP 项目使用教程

2025-04-16 03:10:20作者:裴麒琰

1. 项目目录结构及介绍

FFmpeg-over-IP 是一个允许在拥有 GPU 访问权限的机器上远程转码视频的开源项目。以下是项目的目录结构及其介绍:

ffmpeg-over-ip/
├── bin/             # 存放编译后的客户端和服务器二进制文件
├── cmd/             # 包含 main 函数的包,用于启动客户端和服务器
├── pkg/             # 包含项目的核心逻辑和库
├── .github/         # 存放 GitHub 工作流文件
├── .gitignore       # 定义 Git 忽略的文件和目录
├── LICENSE.md       # 项目许可证文件
├── Makefile         # 项目构建文件,用于构建和安装二进制文件
├── README.md        # 项目说明文件
├── template.ffmpeg-over-ip.client.jsonc  # 客户端配置文件模板
├── template.ffmpeg-over-ip.server.jsonc  # 服务器配置文件模板

2. 项目的启动文件介绍

项目提供了两个主要的启动文件,分别用于启动客户端和服务器:

  • ffmpeg-over-ip-client: 客户端程序,用于发送转码请求到服务器。
  • ffmpeg-over-ip-server: 服务器程序,用于接收客户端的请求并在有 GPU 的机器上执行视频转码。

客户端启动示例:

./bin/ffmpeg-over-ip-client -i input.mp4 -c:v libx264 -preset medium output.mp4

服务器启动示例:

./bin/ffmpeg-over-ip-server

3. 项目的配置文件介绍

FFmpeg-over-IP 使用 JSONC 格式的配置文件,支持在配置文件中添加注释。以下是配置文件的基本结构和介绍:

客户端配置文件 (template.ffmpeg-over-ip.client.jsonc)

{
  // 日志输出位置
  "log": "/tmp/ffmpeg-over-ip-client.log",
  // 服务器地址
  "address": "localhost:5050",
  // 认证密钥(与服务器配置相同)
  "authSecret": "your-secret-here"
}

服务器配置文件 (template.ffmpeg-over-ip.server.jsonc)

{
  // 日志输出位置
  "log": "stdout",
  // 监听地址
  "address": "0.0.0.0:5050",
  // 认证密钥(与客户端配置相同)
  "authSecret": "your-secret-here",
  // 服务器上的 ffmpeg 路径
  "ffmpegPath": "/usr/bin/ffmpeg",
  // 路径重写规则
  "rewrites": [
    // 文件路径重写
    ["/client/path", "/server/path"],
    // 编解码器重写
    ["h264_nvenc", "h264_qsv"]
  ]
}

请根据实际需求修改配置文件中的参数,确保客户端和服务器端的配置文件中的认证密钥一致。

登录后查看全文
热门项目推荐

热门内容推荐

最新内容推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
178
263
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
868
514
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
130
183
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
288
323
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
398
373
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
83
4
cherry-studiocherry-studio
🍒 Cherry Studio 是一款支持多个 LLM 提供商的桌面客户端
TypeScript
600
58
GitNextGitNext
基于可以运行在OpenHarmony的git,提供git客户端操作能力
ArkTS
10
3