搜索
 找回密码
 立即注册

【FFmpeg】ffmpeg+nginx-rtmp实现视频流转发

音视频开发进阶 2022-11-17 21:41:57 32

1.应用场景

目前的摄像头厂家能提供出来的视频流格式有限,且chrome已经禁止了对flash的支持,导致像硬盘录像机这种只能提供rtsp格式流地址的摄像头无法接入Web应用,所以不得不对视频的流地址进行分发,通过代码对流地址中的数据进行切割,非常影响服务的性能,所以采用ffmepg+nginx-rtmp这种无侵入,占用内存小的方式进行视频的分发。

2.软件包

ffmpeg-n4.4-80-gbf87bdd3f6-win64-gpl-4.4.zip

nginx-rtmp-win32-dev.zip

各位看官自行百度下载…

3.使用ffmpeg进行视频流的转流

1.解压zip目录进入文件的bin目录内,有如下几个文件

编辑

添加图片注释,不超过 140 字(可选)

这里要用到的就是ffmpeg.exe

2.常用命令讲解

命令 含义
-i 设定输入视频的地址
-f 设定输出格式
-hls_wrap 设定分割的文件数量
-c copy 拷贝所有的流

3.举一个例子

① 先在电脑上随便建立一个文件夹,我这里建的名称是test

② 进入ffmpeg的bin目录内,打开cmd命令行

③ 输入下列命令

ffmpeg -i 视频流地址 -hls_wrap 10 -c copy -f hls 本地文件夹地址\test\204.m3u8

当命令行出现以下内容时,表示转流成功

编辑切换为居中

添加图片注释,不超过 140 字(可选)

④打开本地建立的test文件夹,会发现有10个ts文件和一个m3u8文件,这里的ts文件,就是ffmpeg将流地址按照时间切片保存下来的视频文件,按照给定的参数进行循环保存覆盖的。

到这里,已经实现了对于视频流的转流及保存,这里可以解决的场景有:

内网的摄像头映射到外网环境

Web端显示摄像头画面

接下来,只需要将这些切片文件一直提供给前端,就能持续的看到画面了。

4.使用nginx-rtmp推送视频文件,让浏览器显示视频。

解压nginx-rtmp-win32-dev.zip文件,进入conf文件夹,编辑nginx.conf文件

<pre class="public-DraftStyleDefault-pre" data-offset-key="600cg-0-0"><pre class="Editable-styled" data-block="true" data-editor="dadd6" data-offset-key="600cg-0-0"><div data-offset-key="600cg-0-0" class="public-DraftStyleDefault-block public-DraftStyleDefault-ltr"><span data-offset-key="600cg-0-0"><span data-text="true">worker_processes 1;

error_log logs/error.log info;

events { worker_connections 1024; }

rtmp { server { listen 1935;

    application live {
        live on;
    }

    application hls {
        live on;
        hls on;  
        hls_path temp/hls;  
        hls_fragment 8s;  
    }
}

}

http { server { listen 8080;

    location / {
        # 这里配置视频文件所在的文件夹,这里就放在nginx-rtmp的html文件夹内,
        # 所以不需要更改。
        root html; 
    }

    location /stat {
        rtmp_stat all;
        rtmp_stat_stylesheet stat.xsl;
    }

    location /stat.xsl {
        root html;
    }

    location /hls {  
        #server hls fragments  
        types{  
            application/vnd.apple.mpegurl m3u8;  
            video/mp2t ts;  
        }  
        alias temp/hls;  
        expires -1;  
    }  
}

}

</span></span></div></pre></pre>

启动nginx-rtmp:

start nginx

打开浏览器,看到以下内容,表示推送成功

编辑

添加图片注释,不超过 140 字(可选)

前端推荐使用Video.js进行视频的展示,这里不做赘述了,使用起来非常简单。

如果有很多视频需要转发,推荐写bat文件进行后台启动

<pre class="public-DraftStyleDefault-pre" data-offset-key="7oi1a-0-0"><pre class="Editable-styled" data-block="true" data-editor="dadd6" data-offset-key="7oi1a-0-0"><div data-offset-key="7oi1a-0-0" class="public-DraftStyleDefault-block public-DraftStyleDefault-ltr"><span data-offset-key="7oi1a-0-0"><span data-text="true">//流地址转发.bat

start cmd /k ffmpeg -i 流地址1 -hls_wrap 10 -c copy -f hls 本地文件夹\1.m3u8 start cmd /k ffmpeg -i 流地址2 -hls_wrap 10 -c copy -f hls 本地文件夹\2.m3u8 start cmd /k ffmpeg -i 流地址3 -hls_wrap 10 -c copy -f hls 本地文件夹\3.m3u8 start cmd /k ffmpeg -i 流地址4 -hls_wrap 10 -c copy -f hls 本地文件夹\4.m3u8 start cmd /k ffmpeg -i 流地址5 -hls_wrap 10 -c copy -f hls 本地文件夹\5.m3u8

</span></span></div></pre></pre>

这样保存成bat,直接双击就能启动

添加图片注释,不超过 140 字(可选)

【FFmpeg】ffmpeg+nginx-rtmp实现视频流转发JeffHan^^的博客-CSDN博客

使用道具 举报

随机推荐

0 回复

游客
返回顶部