windows ffmpeg + nginx + videojs 实现rtmp推流拉流及hls推流拉流直播

2024-01-02 06:40

本文主要是介绍windows ffmpeg + nginx + videojs 实现rtmp推流拉流及hls推流拉流直播,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

上一篇博客已经写了关于windows下面使用ffmpeg+nginx搭建rtmp推流拉流直播环境,可通过ffplay,vlc等pc端客户端软件播放,但因为涉及到浏览器播放原因,rtmp流通过浏览器播放必须要使用flash插件,flash插件因为自身安全性问题已经被整个行业淘汰了,所以只能使用浏览器支持的m3u8格式文件,该文件类似rtmp协议流的flv文件,m3u8是hls协议流的文件

还是从初始开始说吧,上一篇博客说的太过笼统了,以至于被留言说只适合有基础的人看,但问题是我写博客的目的并不是让别人精通而只是入门,毕竟对于音视频这块领域我也算不得什么入门.写博客的目的更多的是让自己需要的时候可以复习.本博客使用的所有资源在最下方下载,nginx已经配好,整个文件下载就能使用,提供的下载包文件目录如下

nginx_1.7.11.3_Gryphon\readme start nginx rtmp.txt包含了所有的指令以及相关的测试结果

一.ffmpeg+nginx 实现rtmp推流拉流直播

首先需要的是配置nginx服务器,nginx作为一款毛子使用了多年的web服务器稳定性没毛病,且国内较多大厂也是用nginx作为web服务器及反向代理服务器,在选择上就不会出在较大问题,最关键的是,nginx使用及其简单,简单到一个对服务器没有任何概念的人也能轻松配置出想要的服务器.关于nginx的详细配置我就不多讲了,细节可以百度,教程也挺多的,我使用的是nginx编译了rtmp模块的Gryphon版本,如果是初始版本的nginx要下载rtmp模块配置下.

在nginx_1.7.11.3_Gryphon\conf目录下面的nginx.conf是nginx启动的默认配置文件,我们主要就在这配置,配置rtmp其实很简单

rtmp {server {listen 1935;chunk_size 4000;application live {live on;}#HLS直播流配置application hls{live on;hls on;hls_path  usr/local/var/www/hls;hls_fragment 1s;}}
}

上面的rtmp server如果只要rtmp服务,可以删除application hls节点

配置好nginx(使用本文下载资源的不需要配置),在nginx.exe目录打开cmd,输入如下指令 nginx -t

 查看配置是否成功,在nginx.exe目录再启动一个cmd,用于关闭nginx服务器

在第一个cmd里面使用nginx.exe -c conf\nginx.conf启动nginx服务器

启动后去任务管理器里面查看下,nginx进程是否运行

如上操作,则启动了一个本地的rtmp服务器

在ffmpeg_nginx_vlc_src2\ffmpeg7_10启动一个cmd,输入如下指令

ffmpeg -rtbufsize 5M -f dshow -i video="USB Camera" -s 640x360 -vcodec libx264 -tune zerolatency -preset ultrafast -b:v 1000k  -g 5 -ab 128k -f flv rtmp://192.168.1.190:1935/live/home

如下则表示ffmpeg在推流给服务器

 在ffmpeg_nginx_vlc_src2\ffmpeg7_10启动一个cmd,输入如下指令

ffplay.exe -fflags nobuffer rtmp://localhost:1935/live/home

如下则表示ffplay拉流成功并播放

vlc的作用仅仅是在刚搭建rtmp服务器时用于检测rtmp流是否推成功,在整个服务器运行成功后其实就没必要使用vlc了,不过我这里还是延时下vlc拉流

安装打开vlc

根据上面步骤连接rtmp服务器,注意网络url地址 rtmp://192.168.1.190:1935/live/home  该地址实际只到rtmp://192.168.1.190:1935/live ,这个live节点就是我们在nginx,conf里面配置的rtmp server节点,后面的home其实是密码或者说是通行证,因为我推流时指定了home

可以看到vlc也可以拉流成功

(关于服务器ip地址自己通过 键入cmd指令 ipconfig查看一下就行,如果是同一台电脑做服务器及客户端,可以直接使用localhost代替本机ip地址)

注意:ffmpeg推流对电脑性能要求较高,如电脑性能达不到要求需要适当调整ffmpeg录制指令,详情可在nginx_1.7.11.3_Gryphon\readme start nginx rtmp.txt文件找到或者自己百度即可.

该ffmpeg+nginx 的rtmp推流拉流方案我连续测试了12小时,并未发现异常,初步结论:服务器搭建成功.

二.ffmpeg+nginx+video. js 实现hls推流及网页拉流直播

在文章的一开始就提到了网页播放直播流的方案取舍,这里不再赘述,关于网页播放的技术,本文采用的播放m3u8格式文件,如有其他方案可留言,有空我会测试下

在上面ffmpeg推流的cmd中输入q停止推流,关闭ffplay的播放窗口,注意不要关闭cmd窗体

因为我启动的nginx已经配置了hls服务,这里不需要重新配置了,但还是讲下hls的配置,在nginx.conf文件中配置如下

rtmp {server {listen 1935;chunk_size 4000;application live {live on;}#HLS直播流配置application hls{live on;hls on;hls_path  usr/local/var/www/hls;hls_fragment 1s;}}
}

值得注意的是 hls_path的设置 ,通过hls_path设置hls协议切片的m3u8文件及ts文件的本地存储位置,仔细比较实际文件目录,可以发下跟目录是nginx.exe所在目录

在nginx.conf文件的http server中添加配置如下

location /hls{#设置跨域add_header Cache-Control no-cache;add_header 'Access-Control-Allow-Origin' '*' always;add_header 'Access-Control-Expose-Headers' 'Content-Length,Content-Range';add_header 'Access-Control-Allow-Headers' 'Range';#serve HLS fragmentstypes{application/vnd.apple.mpegurl m3u8;video/mp2t ts;}root usr/local/var/www;#add_header Cache-Control no-cache;expires -1;}

尤其注意types中的application/vnd.apple.mpegurl m3u8配置及 root usr/local/var/www目录配置

配置时要注意配置跨域,如不配置跨域,则运行html拉流时出现Access to XMLHttpRequest at http://xxx.xxx from origin 'http://localhost:8800' has been 问题

下载本文下面链接包的不需要做任何修改,仅需通过本文注意配置要点即可

在运行ffmpeg指令的cmd中输入如下指令

ffmpeg -rtbufsize 5M -f dshow -i video="USB Camera" -s 640x360 -vcodec libx264 -tune zerolatency -preset ultrafast -b:v 1000k  -g 5 -ab 128k -f flv rtmp://192.168.1.190:1935/hls/home

 如下表示推流成功

下面通过ffplay拉流播放

输入如下

ffplay -i "http://192.168.1.190:8800/hls/home.m3u8" 

通过ffplay播放成功,我们的目的不是通过客户端播放而是用浏览器播放,在此只是验证了hls流推流成功

注意:上面的ffmpeg指令出现红字提示,有可能推流失败,可重新推流

下面使用浏览器播放hls流

打开ffmpeg_nginx_vlc_src2\vide7.10.2\vioodejs_player.html

可以看到浏览器播放成功

使用本博客的资源仅需要在html代码里修改hls流地址即可

上面完整的运行了hls推流与拉流播放,此时在本地指定的文件夹下保存了hls流文件,在ffmpeg_nginx_vlc_src2\nginx_1.7.11.3_Gryphon\usr\local\var\www\hls文件夹下

ts文件是视频切片文件,m3u8是播放文件,里面存放的是当前播放的切片文件名

关闭流程为 先关闭拉流播放端  再关闭推流端 最后关闭nginx服务器(关闭没有严格顺序)

在上面输入nginx -t的命令行输入nginx -s stop关闭nginx,去任务管理器确认nignx进程是被关闭

以上.

本博客资源 百度网盘下载地址 百度网盘  提取码:rerk

csdn下载
 
 

 

 

 

这篇关于windows ffmpeg + nginx + videojs 实现rtmp推流拉流及hls推流拉流直播的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/561622

相关文章

SpringBoot集成XXL-JOB实现任务管理全流程

《SpringBoot集成XXL-JOB实现任务管理全流程》XXL-JOB是一款轻量级分布式任务调度平台,功能丰富、界面简洁、易于扩展,本文介绍如何通过SpringBoot项目,使用RestTempl... 目录一、前言二、项目结构简述三、Maven 依赖四、Controller 代码详解五、Service

Python 基于http.server模块实现简单http服务的代码举例

《Python基于http.server模块实现简单http服务的代码举例》Pythonhttp.server模块通过继承BaseHTTPRequestHandler处理HTTP请求,使用Threa... 目录测试环境代码实现相关介绍模块简介类及相关函数简介参考链接测试环境win11专业版python

GO语言短变量声明的实现示例

《GO语言短变量声明的实现示例》在Go语言中,短变量声明是一种简洁的变量声明方式,使用:=运算符,可以自动推断变量类型,下面就来具体介绍一下如何使用,感兴趣的可以了解一下... 目录基本语法功能特点与var的区别适用场景注意事项基本语法variableName := value功能特点1、自动类型推

基于Python实现自动化邮件发送系统的完整指南

《基于Python实现自动化邮件发送系统的完整指南》在现代软件开发和自动化流程中,邮件通知是一个常见且实用的功能,无论是用于发送报告、告警信息还是用户提醒,通过Python实现自动化的邮件发送功能都能... 目录一、前言:二、项目概述三、配置文件 `.env` 解析四、代码结构解析1. 导入模块2. 加载环

使用shardingsphere实现mysql数据库分片方式

《使用shardingsphere实现mysql数据库分片方式》本文介绍如何使用ShardingSphere-JDBC在SpringBoot中实现MySQL水平分库,涵盖分片策略、路由算法及零侵入配置... 目录一、ShardingSphere 简介1.1 对比1.2 核心概念1.3 Sharding-Sp

Java+AI驱动实现PDF文件数据提取与解析

《Java+AI驱动实现PDF文件数据提取与解析》本文将和大家分享一套基于AI的体检报告智能评估方案,详细介绍从PDF上传、内容提取到AI分析、数据存储的全流程自动化实现方法,感兴趣的可以了解下... 目录一、核心流程:从上传到评估的完整链路二、第一步:解析 PDF,提取体检报告内容1. 引入依赖2. 封装

Java实现复杂查询优化的7个技巧小结

《Java实现复杂查询优化的7个技巧小结》在Java项目中,复杂查询是开发者面临的“硬骨头”,本文将通过7个实战技巧,结合代码示例和性能对比,手把手教你如何让复杂查询变得优雅,大家可以根据需求进行选择... 目录一、复杂查询的痛点:为何你的代码“又臭又长”1.1冗余变量与中间状态1.2重复查询与性能陷阱1.

python 线程池顺序执行的方法实现

《python线程池顺序执行的方法实现》在Python中,线程池默认是并发执行任务的,但若需要实现任务的顺序执行,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋... 目录方案一:强制单线程(伪顺序执行)方案二:按提交顺序获取结果方案三:任务间依赖控制方案四:队列顺序消

Nginx中配置使用非默认80端口进行服务的完整指南

《Nginx中配置使用非默认80端口进行服务的完整指南》在实际生产环境中,我们经常需要将Nginx配置在其他端口上运行,本文将详细介绍如何在Nginx中配置使用非默认端口进行服务,希望对大家有所帮助... 目录一、为什么需要使用非默认端口二、配置Nginx使用非默认端口的基本方法2.1 修改listen指令

Redis实现分布式锁全过程

《Redis实现分布式锁全过程》文章介绍Redis实现分布式锁的方法,包括使用SETNX和EXPIRE命令确保互斥性与防死锁,Redisson客户端提供的便捷接口,以及Redlock算法通过多节点共识... 目录Redis实现分布式锁1. 分布式锁的基本原理2. 使用 Redis 实现分布式锁2.1 获取锁