FFmpeg解决视频播放加载卡顿问题(FFmpeg+M3U8分片)

news2024/12/25 2:19:38

FFmpeg解决视频播放加载卡顿问题(FFmpeg+M3U8分片)

在这里插入图片描述

在这静谧的时光里,我们能够更清晰地审视自己,思考未来的方向。每一步的坚实,都是对勇气的拥抱,每一个夜晚的努力,都是对未来的信仰。不要害怕独行,因为正是在寂静中,我们更能听见内心深处的声音,更能感受到梦想的脉动。

1.问题回顾

为什么会讨论这个问题呢,原因是我们做了一个在线培训系统,但是存在视频播放卡顿问题,按道理来说,这个是不应该的!因为服务器已经是顶配了,宽带甚至达到了上百,但是很可惜,几个人看视频都会卡顿!而且,这个对象存储还用的是华为云,当然,这里承认一件事,我们没有使用CDN。

这里我们大概介绍一下啥叫做CDN,作为一个拓展,就开始正文:

CDN(Content Delivery Network)是一种用于提高网站性能、可用性和安全性的网络架构。它通过将内容分发到离用户更近的服务器节点,从而减少延迟、提高加载速度,同时能够有效处理大流量和提供安全保障。以下是CDN技术的一些关键特点和组成部分:

1. 关键特点:

  • 较低的延迟和更快的加载速度: CDN通过在全球范围内的多个服务器节点分发内容,使用户能够从距离更近的服务器获取数据,从而减少延迟和提高加载速度。

  • 更高的可用性和可靠性: CDN通过将内容存储在多个地理位置的服务器上,提高了内容的冗余度,从而增加了系统的可用性和可靠性。

  • 减轻源服务器负担: CDN能够缓存并提供静态内容,减轻了源服务器的负载,使其更专注于动态内容的生成。

  • 大流量处理能力: CDN分布式的特性允许它有效地处理大量的并发请求,从而保证了高效的内容分发。

  • 提供安全性和防护: CDN通常具备一定的安全功能,例如DDoS攻击防护、Web应用程序防火墙(WAF)等,以增强对网站的安全保障。

2. CDN的组成部分:

  • 边缘服务器节点: CDN的核心组成部分是分布在全球各地的边缘服务器节点。这些节点存储着静态内容的副本,以便更快地响应用户请求。

  • 内容分发服务器(CDN服务器): 负责协调用户请求的CDN服务器,决定从哪个边缘节点提供服务,并负责内容的分发和管理。

  • 负载均衡器: 用于平衡用户请求的负载,确保每个边缘节点都得到合理的请求分发。

  • 缓存: 用于存储和管理缓存的组件,以便在需要时能够快速提供内容。

  • 安全功能: 包括DDoS防护、SSL加密、WAF等安全措施,以保护网站免受恶意攻击。

  • 分发协议: 用于确定如何将内容传递到用户的协议,常见的包括HTTP、HTTPS、以及最近的HTTP/2和HTTP/3。

3. CDN的工作原理:

  1. DNS解析: 用户发起请求时,通过DNS解析获得最近的CDN边缘节点的IP地址。

  2. 请求路由: CDN服务器根据负载均衡策略,将用户请求路由到最合适的边缘节点。

  3. 内容缓存: 边缘节点检查是否有所请求内容的缓存。如果存在,直接返回缓存内容,否则向源服务器请求并缓存内容。

  4. 内容返回: 边缘节点将请求的内容返回给用户,完成请求-响应过程。

CDN技术在提高网站性能、可用性和安全性方面发挥了重要作用,特别是在大规模内容分发的场景中,CDN的应用变得尤为关键。

2.技术解决

1.产品介绍

在经过大量的百度学习,我们发现一款开源大作:FFmpeg。对,就是这个神器!此物不仅仅说是应用于我们编程圈,再音视频多媒体圈也是颇具盛名!

FFmpeg(Fast Forward MPEG)是一个开源的多媒体处理工具集,它包含了音频和视频处理库、编码器、解码器、转码器等多种工具。以下是FFmpeg的主要功能介绍:

  1. 音视频编解码(Codec):
    • FFmpeg支持各种音频和视频编解码器,包括常见的H.264、H.265、AAC、MP3等,使其能够处理各种媒体格式。
  2. 格式转换:
    • 可以将不同格式的音频和视频文件相互转换,例如将MP4转换为AVI、将WAV转换为MP3等。
  3. 流媒体处理:
    • FFmpeg支持从网络摄像头、文件、或其他来源捕获音视频流,也能将处理后的流推送到服务器或其他设备。
  4. 图像处理:
    • FFmpeg不仅仅可以处理音视频,还支持图像处理,如提取视频帧,合成图片和视频等。
  5. 剪辑和编辑:
    • 可以对音视频进行剪辑和编辑,包括裁剪、剪切、拼接等操作。
  6. 字幕处理:
    • 支持字幕的添加、移除和编辑,可以将字幕嵌入到视频中或者从视频中提取字幕。
  7. 音频处理:
    • 提供了丰富的音频处理功能,包括音频的剪辑、混音、音量调节等。
  8. 实时视频处理:
    • FFmpeg能够处理实时的音视频流,适用于直播、视频会议等场景。
  9. 滤镜和效果:
    • 支持各种滤镜和效果,如模糊、旋转、调整亮度、对比度等。

FFmpeg的强大功能使其成为许多多媒体应用和服务的核心组件,例如视频编辑软件、流媒体服务器、嵌入式设备等。由于其广泛的支持和社区贡献,FFmpeg已经成为处理多媒体数据的重要工具之一。

由于我们的业务逻辑涉及到流媒体,那么,我们就把关注点放在流媒体处理!打蛇打七寸,我们着重下手!

2.流媒体处理

流媒体处理是一种通过网络实时传输音频和视频数据的技术,允许用户在数据传输的同时观看或听取内容,而不需要等待完整的文件下载。FFmpeg是一个强大的工具,广泛用于流媒体处理。以下是流媒体处理的主要方面以及FFmpeg在这些方面的应用:

  1. 流媒体捕获:
    • FFmpeg可以从各种来源捕获音频和视频流,包括摄像头、麦克风、文件、URL等。通过使用FFmpeg的输入模块,用户可以轻松地实现从这些源中捕获多媒体数据。
# 从摄像头捕获视频
ffmpeg -f v4l2 -i /dev/video0 output.mp4

# 从麦克风捕获音频
ffmpeg -f alsa -i hw:0 output.wav

# 从URL捕获网络流
ffmpeg -i http://example.com/stream.m3u8 output.mp4
  1. 流媒体转码:
    • 在流媒体处理中,有时需要将音视频数据转码为特定格式或编码,以适应不同的设备或网络条件。FFmpeg提供了广泛的编码器和解码器支持,使得转码变得简单。
# 将输入流转码为H.264视频和AAC音频
ffmpeg -i input.mp4 -c:v libx264 -c:a aac output.mp4
  1. 流媒体推送:
    • FFmpeg可以将处理后的音视频流推送到流媒体服务器,以便在网络上进行分发。这对于实时直播和视频会议非常有用。
# 推送到RTMP服务器
ffmpeg -i input.mp4 -c:v libx264 -c:a aac -f flv rtmp://example.com/live/stream
  1. 实时流媒体处理:
    • FFmpeg支持实时处理音视频流,适用于需要低延迟的应用,如实时直播和视频通话。
# 实时捕获摄像头并推送到RTMP服务器
ffmpeg -f v4l2 -i /dev/video0 -c:v libx264 -c:a aac -f flv rtmp://example.com/live/stream
  1. 流媒体过滤器:
    • FFmpeg提供了丰富的过滤器,可以对音视频流进行各种处理,如添加水印、调整亮度、旋转、裁剪等。
# 在视频上添加水印
ffmpeg -i input.mp4 -i watermark.png -filter_complex overlay=10:10 output.mp4
  1. 自适应比特率:
    • FFmpeg可以实现自适应比特率(Adaptive Bitrate Streaming,ABR),以根据用户的网络条件自动调整流的质量。
# 使用多个输出流实现自适应比特率
ffmpeg -i input.mp4 -c:v libx264 -b:v 2000k -c:a aac -b:a 128k -f hls -hls_time 4 -hls_playlist_type vod output.m3u8

上述示例展示了一些FFmpeg在流媒体处理中的常见用法。这些功能使FFmpeg成为流媒体处理的强大工具,适用于多种场景,包括在线直播、视频会议、实时通信等。

3.问题深入

由于我也是IT小学生,这里我简单说一下对于视频播放卡顿我的个人理解:

作为项目的参与者,我们是使用了华为云的对象存储,但是,在视频的播放的时候,我们并没有学习人家其他网站一样,使用m3u8格式进行分片传输,而是一股脑的直接把视频地址抛给前端,自己加载播放,这样子呢,如果大量请求,肯定存在卡顿现象。所以,要么转码,要么分片分批次

视频转码是将一个视频文件从一种编码或格式转换为另一种编码或格式的过程。这过程的目的是为了满足不同终端设备、网络环境或应用场景的需求,以提高视频的兼容性、播放效果、传输效率和存储效率。视频转码有以下一些主要作用:

  1. 兼容性提升: 不同的终端设备和播放器对视频格式和编码的支持有所差异。通过转码,可以将视频转换为广泛支持的格式,确保在各种设备和平台上都能正常播放。

  2. 播放效果优化: 转码可以改变视频的分辨率、比特率、帧率等参数,以适应不同的播放环境。例如,在移动设备上,可以将视频分辨率调整为适应小屏幕,以提高观看体验。

  3. 网络传输效率提高: 不同的网络环境对视频传输的带宽要求不同。通过调整视频的压缩率,可以降低视频文件的大小,提高在低带宽环境下的传输效率。

  4. 存储空间节省: 对于大型视频平台或存储服务提供商来说,原始视频文件可能占用大量存储空间。通过转码,可以将视频文件压缩成更小的文件,从而降低存储成本。

  5. 支持多码率自适应流: 多码率自适应流(Adaptive Bitrate Streaming,ABR)是一种通过提供不同比特率的视频流,以适应用户网络带宽的技术。转码可以生成多个不同比特率的视频流,以支持ABR,从而在播放时能够根据用户的网络情况动态切换清晰度。

  6. 格式转换: 转码可以将视频从一种格式转换为另一种格式,例如从AVI到MP4、从MKV到WebM等。这有助于确保视频在不同平台和设备上的兼容性。

M3U8是一种用于指定多媒体播放列表的格式,常用于流媒体协议中,特别是用于HTTP Live Streaming(HLS)协议。HLS通过将整个视频分成一系列小的、独立的.ts文件(Transport Stream),并使用M3U8播放列表来指导播放器在不同比特率和分辨率之间切换,以实现自适应流媒体传输。以下是M3U8分片的基本工作原理:

  1. 切片生成: 视频文件首先被切分成一系列小的.ts文件,每个文件包含视频的一小部分内容。这些切片通常有相同的持续时间,例如2秒或10秒。

  2. M3U8播放列表生成: 为了指导播放器正确地按顺序播放这些切片,一个M3U8播放列表文件被创建。该文件包含了所有切片的信息,包括其相对路径、时长、序号等。在M3U8文件中,包括了不同清晰度(多码率自适应流)的版本,以便播放器可以根据网络条件选择最合适的版本。

  3. 播放器请求和播放: 播放器通过HTTP请求M3U8文件,并解析其中的信息。然后,它根据M3U8文件中的信息逐个请求切片文件,并按顺序播放这些切片。

这个过程的优势在于,它允许根据用户的网络状况和设备性能自适应地调整视频质量。如果用户的网络速度较慢,播放器可以选择较低分辨率和比特率的切片,以确保连续的播放。如果网络条件改善,播放器可以选择更高质量的切片,提供更清晰的画面。

4.问题解决

使用FFmpeg来实现M3U8分片,通常需要进行两个主要步骤:首先是将原始视频文件切分成一系列小的.ts文件,然后是生成一个包含这些切片信息的M3U8播放列表。以下是一个简单的示例:

步骤1:切片生成

使用以下命令将原始视频文件切分成.ts文件:

ffmpeg -i input_video.mp4 -c copy -bsf:v h264_mp4toannexb -f segment -segment_time 10 -segment_list output_playlist.m3u8 -segment_format mpegts output_%03d.ts
  • -i input_video.mp4:指定输入视频文件。
  • -c copy:保持视频和音频的原始编码。
  • -bsf:v h264_mp4toannexb:将H.264编码的视频转换为MPEG-TS格式。
  • -f segment:指定输出格式为segment。
  • -segment_time 10:每个切片的时长,这里设置为10秒。
  • -segment_list output_playlist.m3u8:指定M3U8播放列表的文件名。
  • -segment_format mpegts:指定切片的格式为MPEG-TS。
  • output_%03d.ts:输出切片的文件名模板,%03d 表示三位数的序号。

步骤2:生成M3U8播放列表

使用以下命令生成M3U8播放列表:

ffmpeg -f concat -safe 0 -i output_playlist.m3u8 -c copy -bsf:a aac_adtstoasc output_final.m3u8
  • -f concat:指定输入文件格式为concat。
  • -safe 0:允许使用相对路径。
  • -i output_playlist.m3u8:指定输入M3U8播放列表文件。
  • -c copy:保持原始编码。
  • -bsf:a aac_adtstoasc:将AAC音频流的ADTS头转换为MPEG-4 Audio(asc)格式。

最终,output_final.m3u8 将包含所有切片信息,可以被用作HLS流的播放列表。

请注意,这只是一个简单的示例,实际应用中可能需要更多的参数配置,例如视频编码选项、分辨率、比特率等,以满足特定需求。此外,FFmpeg的命令行参数可能会根据不同的版本有所变化,请根据您使用的版本查阅相关文档。

3.代码实现

使用Java代码调用FFmpeg库以完成M3U8分片的操作可以使用Java的ProcessBuilder类。以下是一个简单的Java代码示例,用于调用FFmpeg执行上述步骤:

import java.io.IOException;

public class FFmpegHLSProcessor {

    public static void main(String[] args) {
        String inputVideoPath = "input_video.mp4";
        String outputPlaylistPath = "output_playlist.m3u8";
        String outputFinalPath = "output_final.m3u8";

        // Step 1: 切片生成
        try {
            ProcessBuilder processBuilder = new ProcessBuilder(
                "ffmpeg", "-i", inputVideoPath,
                "-c", "copy", "-bsf:v", "h264_mp4toannexb",
                "-f", "segment", "-segment_time", "10",
                "-segment_list", outputPlaylistPath,
                "-segment_format", "mpegts",
                "output_%03d.ts"
            );
            processBuilder.redirectErrorStream(true);
            Process process = processBuilder.start();
            process.waitFor();
        } catch (IOException | InterruptedException e) {
            e.printStackTrace();
        }

        // Step 2: 生成M3U8播放列表
        try {
            ProcessBuilder processBuilder = new ProcessBuilder(
                "ffmpeg", "-f", "concat", "-safe", "0", "-i", outputPlaylistPath,
                "-c", "copy", "-bsf:a", "aac_adtstoasc",
                outputFinalPath
            );
            processBuilder.redirectErrorStream(true);
            Process process = processBuilder.start();
            process.waitFor();
        } catch (IOException | InterruptedException e) {
            e.printStackTrace();
        }
    }
}

请确保系统上已经安装了FFmpeg,并且Java应用程序可以调用它。

4.总结

大概得解决思路如上,当然,FFmpeg是免费的,CDN是增值服务,各有优劣!

对于FFmpeg+M3U8实现的分片技术,实际生产中肯定还会涉及到复杂的业务逻辑,更具具体情况请多加揣测。

拜拜,我要设计业务逻辑去了!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1387018.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

机器学习算法实战案例:时间序列数据最全的预处理方法总结

文章目录 1 缺失值处理1.1 统计缺失值1.2 删除缺失值1.3 指定值填充1.4 均值/中位数/众数填充1.5 前后项填充 2 异常值处理2.1 3σ原则分析2.2 箱型图分析 3 重复值处理3.1 重复值计数3.2 drop_duplicates重复值处理 3 数据归一化/标准化3.1 0-1标准化3.2 Z-score标准化 技术交…

使用Openssl生成Https免费证书以及Nginx配置

1 证书和私钥的生成 1.创建服务器证书密钥文件 server.key: openssl genrsa -des3 -out server.key 2048 输入密码,确认密码,自己随便定义,但是要记住,后面会用到。 2.创建服务器证书的申请文件 server.csr openssl r…

外包干了4年,废了···

有一说一,外包没有给很高的薪资,是真不能干呀! 先说一下自己的情况,大专生,19年通过校招进入湖南某软件公司,干了接近4年的功能测试,今年年初,感觉自己不能够在这样下去了&#xff0…

Linux的基础命令学习

pwd - 显示当前工作目录的路径 cd - 切换工作目录,ls - 列出当前目录的文件和子目录 rm - 删除文件或目录 mkdir - 创建新目录 rm - 删除目录 nano/vi - 编辑文本文件,按Enter键进入 之后按i键就可以进入写入模式 之后输入文字以后按Esc键与:q就不保…

【设计模式-05】Facade门面Mediator调停者 | Decorator装饰器 | Chain Of Responsibility责任链

Facade门面Mediator调停者 1、Facade门面图解 2、Mediator调停者 一般是系统内部相互交错,比如消息中间件(MQ)就是这种设计模式,对各个功能或系统之间进行解耦。 Decorator装饰器 1、问题 2、解决方案 Chain Of Responsibility责任链 一、例子场景 业…

(Java企业 / 公司项目)JMeter接口压测使用(保姆式手把手教会)

一. JMeter简介认识(重点是下面的使用方法) JMeter是一个开源的Java应用程序,由Apache软件基金会开发和维护,可用于性能测试、压力测试、接口测试等。 1. 原理 JMeter的基本原理是模拟多用户并发访问应用程序,通过发…

手把手教你如何搭建Spring本地编译环境

大家好,我是极客涛,不知道小伙伴有没有和我一样的情况,在阅读Spring源码时,只通过静态的代码阅读很难有更深刻的理解,所以建议通过写测试类进行debug的方式,对核心的代码进行运行时的状态调试,这…

2024年腾讯云服务器活动价格整理汇总,5年和三年选择

腾讯云服务器租用价格表:轻量应用服务器2核2G3M价格62元一年、2核2G4M价格118元一年,540元三年、2核4G5M带宽218元一年,2核4G5M带宽756元三年、轻量4核8G12M服务器446元一年、646元15个月,云服务器CVM S5实例2核2G配置280.8元一年…

TLS握手流程分析

1.SSL/TLS 历史 HTTP 是明文传输的协议,可能受到第三方的攻击,非常不安全。因此才诞生 “HTTPS”。 这个 “S” 表示 SSL/TLS 协议,用公式说明:HTTPS HTTP SSL(TLS)。 其中 SSL 即安全套接层(Secure Sockets Layer&…

【开发篇】四、MAT堆内存分析(Memory Analyzer Tool)

文章目录 1、使用2、报错3、MAT支配树4、MAT内存泄漏的检测原理5、导出运行中系统的内存快照6、补充 1、使用 内存溢出后,分析泄露的思路是: 在OOM前,将整个堆内存保存成一个hprof文件MAT打开hprof文件,MAT自行分析可疑对象 添…

模拟器安装XPosed框架教程

Xposed框架下载(搞不懂就先看完本篇教程再下载) 99%的情况只需要下载里面的XPosed鸭就行了 安卓8及以下XPosed框架 - 多开鸭模拟器安装XPosed框架图文视频教程 关于本站XPosed框架的说明 XPosed框架(即XP框架),由rovo89开发。适用于安卓7以…

Kafka消费流程

Kafka消费流程 消息是如何被消费者消费掉的。其中最核心的有以下内容。 1、多线程安全问题 2、群组协调 3、分区再均衡 1.多线程安全问题 当多个线程访问某个类时,这个类始终都能表现出正确的行为,那么就称这个类是线程安全的。 对于线程安全&…

HNU-算法设计与分析-实验4

算法设计与分析实验4 计科210X 甘晴void 202108010XXX 目录 文章目录 算法设计与分析<br>实验41 回溯算法求解0-1背包问题问题重述想法代码验证算法分析 2 回溯算法实现题5-4运动员最佳配对问题问题重述想法代码验证算法分析 3 分支限界法求解0-1背包问题问题重述想法…

OpenGL Assimp加载各类型模型(.obj、.fbx、.glb、.3ds)

1.简介 本博客以.glb格式为例&#xff0c;加载glb格式的3d模型&#xff0c;网上找了一圈&#xff0c;基本上都是根据OpenGL官方示例&#xff0c;加载.obj格式的3d模型。 下面以.obj和.glb格式的3D模型简单介绍一下。 常见的.obj格式的3D模型如下所示&#xff1a;纹理都已经被…

FineBI实战项目一(23):订单商品分类词云图分析开发

点击新建组件&#xff0c;创建订单商品分类词云图组件。 选择词云&#xff0c;拖拽catName到颜色和文本&#xff0c;拖拽cat到大小。 将组件拖拽到仪表板。 结果如下&#xff1a;

MYSQL的学习——单行函数详解

目录 1. 数值函数 1) 基本函数 2) 角度与弧度互换函数 3) 三角函数 4) 指数与对数函数 5) 进制间的转换 2. 字符串函数 3. 日期和时间函数 1) 获取日期、时间 2) 日期与时间戳的转换 3) 获取月份、星期、星期数、天数等函数 4) 日期的操作函数 5) 时间和秒钟转换的…

商业世界,从2023到2024

作者&#xff5c;潮汐商业评论 编辑&#xff5c;Ray 变化总在发生&#xff0c;你不去迎接进步的变化&#xff0c;就会等到退步的变化。 —— 查理.芒格 2023, 我们似乎总在不断告别。从“一生自由”的大家黄永玉到“智慧”投资家查理.芒格&#xff0c;再到写出《不能承受的生命…

条款24:若所有参数皆需类型转换,请为此采用非成员函数

设计一个表示有理数的类时&#xff0c;允许从整数隐式转换为有理数是有用的&#xff1a; class Rational { public:Rational(int numerator 0, // 该构造函数没有explicit限制;int denominator 1); int numerator() const; int denominator() const; const Rational opera…

如何用GPT制作PPT和写代码?

详情点击链接&#xff1a;如何用GPT制作PPT和写模型代码&#xff1f; 一OpenAI 1.最新大模型GPT-4 Turbo 2.最新发布的高级数据分析&#xff0c;AI画图&#xff0c;图像识别&#xff0c;文档API 3.GPT Store 4.从0到1创建自己的GPT应用 5. 模型Gemini以及大模型Claude2二定…

04.SpringCloud网关-gateway

1.Gateway服务网关 Spring Cloud Gateway 是 Spring Cloud 的一个全新项目&#xff0c;该项目是基于 Spring 5.0&#xff0c;Spring Boot 2.0 和 Project Reactor 等响应式编程和事件流技术开发的网关&#xff0c;它旨在为微服务架构提供一种简单有效的统一的 API 路由管理方式…