ffmpeg+nginx+video实现rtsp流转hls流,web页面播放

2024-06-22 10:04

本文主要是介绍ffmpeg+nginx+video实现rtsp流转hls流,web页面播放,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

项目场景:

最近调试海康摄像头需要将rtsp流在html页面播放,因为不想去折腾推拉流,所以我选择ffmpeg转hls流,nginx转发,html直接访问就好了

1.首先要下载nginx和ffmpeg

附上下载地址:

nginx nginx news

ffmpeg https://github.com/BtbN/FFmpeg-Builds/releases

ffmpeg解压后 需配置环境变量

2.使用FFmpeg将RTSP视频源转换为HLS格式

在cmd命令窗口中执行下列命令

ffmpeg -i rtsp://admin:zkgd@wdv@192.168.3.202:554/Streaming/Channels/1 -c:v libx264 -preset medium -crf 23 -c:a aac -strict -2 -b:a 160k -start_number 0 -hls_time 10 -hls_list_size 0 -f hls E:/vedio/hls/test.m3u8
  • ffmpeg: 这是调用FFmpeg命令行工具的部分。

  • -i rtsp://admin:zkgd@wdv@192.168.3.202:554/Streaming/Channels/1:这一部分指定了输入源,即要转换的RTSP视频流地址。其中,admin:zkgd@wdv是用于访问该视频流的认证信息(用户名和密码),192.168.3.202:554是视频服务器的IP地址和端口号,Streaming/Channels/1通常表示视频流的一个通道。

  • -c:v libx264:指定视频编码器为libx264,这是一个广泛使用的H.264视频编码库,适用于输出高质量且兼容性好的视频流。

  • -preset medium:设置x264的预设值为medium,这会影响编码速度和输出文件的大小。medium是一个平衡了编码速度和压缩效率的选项。

  • -crf 23:Constant Rate Factor (CRF) 控制视频的质量。值越小,质量越高,但文件也越大。23是一个常见的选择,能提供不错的平衡。

  • -c:a aac -strict -2:指定音频编码器为AAC,这是一种高效且广泛支持的音频编码格式。-strict -2是为了兼容旧版FFmpeg中对AAC的支持设置的,新版本可能不需要这个参数。

  • -b:a 160k:设定音频比特率为160kbps,控制音频的质量和大小。

  • -start_number 0:指定输出的TS片段从0开始编号,这对于某些播放器的连续播放有帮助。

  • -hls_time 10:设置HLS切片的时间长度为10秒,意味着视频会每10秒切分为一个小段(TS文件)。

  • -hls_list_size 0:此设置表示HLS播放列表不会限制存储的分片数量,0意味着所有生成的分片都将被保存在列表中,直到手动清理。

  • -f hls:指定输出格式为HLS。

  • E:/vedio/hls/test.m3u8:这是输出文件的路径和名称,表示生成的HLS播放列表(m3u8文件)及相应的视频分片将保存在E盘的vedio/hls目录下,文件名为test.m3u8。

  • 命令执行成功后会看道如下界面

3.修改nginx配置文件


#user  nobody;
worker_processes  1;#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;#pid        logs/nginx.pid;events {worker_connections  1024;
}http {include       mime.types;default_type  application/octet-stream;#log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '#                  '$status $body_bytes_sent "$http_referer" '#                  '"$http_user_agent" "$http_x_forwarded_for"';#access_log  logs/access.log  main;sendfile        on;#tcp_nopush     on;#keepalive_timeout  0;keepalive_timeout  65;#gzip  on;server {listen       81;server_name  localhost;#charset koi8-r;#access_log  logs/host.access.log  main;location / {root   E:/environment/nginx-1.24.0/www/test;index  index.html index.htm demo.html;}location /hls {types {application/vnd.apple.mpegurl m3u8;video/mp2t ts;}alias   E:/vedio/hls;add_header Cache-Control no-cache ;add_header Access-Control-Allow-Origin *;}#error_page  404              /404.html;# redirect server error pages to the static page /50x.html#error_page   500 502 503 504  /50x.html;location = /50x.html {root   html;}}}

4.访问  localhost:81

5.补充:py定时清理文件小脚本,需安装py环境

import os
import time
from datetime import datetime, timedelta# 目标文件夹路径
target_folder = r"E:\vedio\hls"
# 检查时间阈值(5分钟前)
time_threshold = datetime.now() - timedelta(minutes=5)def delete_old_files(folder_path, threshold):"""删除指定文件夹下指定时间以前创建的文件"""for filename in os.listdir(folder_path):file_path = os.path.join(folder_path, filename)# 确保是文件且不是目录if os.path.isfile(file_path):# 获取文件创建时间creation_time = datetime.fromtimestamp(os.path.getctime(file_path))# 如果文件创建时间早于阈值时间,则删除if creation_time < threshold:print(f"删除文件: {file_path}")os.remove(file_path)def main():while True:print("正在检查并删除旧文件...")delete_old_files(target_folder, time_threshold)# 每10分钟执行一次time.sleep(360)  # 360秒等于10分钟if __name__ == "__main__":print("脚本开始运行...")main()

执行效果如下

完成

这篇关于ffmpeg+nginx+video实现rtsp流转hls流,web页面播放的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

C++对象布局及多态实现探索之内存布局(整理的很多链接)

本文通过观察对象的内存布局,跟踪函数调用的汇编代码。分析了C++对象内存的布局情况,虚函数的执行方式,以及虚继承,等等 文章链接:http://dev.yesky.com/254/2191254.shtml      论C/C++函数间动态内存的传递 (2005-07-30)   当你涉及到C/C++的核心编程的时候,你会无止境地与内存管理打交道。 文章链接:http://dev.yesky

JAVA读取MongoDB中的二进制图片并显示在页面上

1:Jsp页面: <td><img src="${ctx}/mongoImg/show"></td> 2:xml配置: <?xml version="1.0" encoding="UTF-8"?><beans xmlns="http://www.springframework.org/schema/beans"xmlns:xsi="http://www.w3.org/2001

通过SSH隧道实现通过远程服务器上外网

搭建隧道 autossh -M 0 -f -D 1080 -C -N user1@remotehost##验证隧道是否生效,查看1080端口是否启动netstat -tuln | grep 1080## 测试ssh 隧道是否生效curl -x socks5h://127.0.0.1:1080 -I http://www.github.com 将autossh 设置为服务,隧道开机启动

JavaScript全屏,监听页面是否全屏

在JavaScript中,直接监听浏览器是否进入全屏模式并不直接支持,因为全屏API主要是关于请求和退出全屏模式的,而没有直接的监听器可以告知页面何时进入或退出全屏模式。但是,你可以通过在你的代码中跟踪全屏状态的改变来模拟这个功能。 以下是一个基本的示例,展示了如何使用全屏API来请求全屏模式,并在请求成功或失败时更新一个状态变量: javascriptlet isInFullscreen =

时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测

时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测 目录 时序预测 | MATLAB实现LSTM时间序列未来多步预测-递归预测基本介绍程序设计参考资料 基本介绍 MATLAB实现LSTM时间序列未来多步预测-递归预测。LSTM是一种含有LSTM区块(blocks)或其他的一种类神经网络,文献或其他资料中LSTM区块可能被描述成智能网络单元,因为

vue项目集成CanvasEditor实现Word在线编辑器

CanvasEditor实现Word在线编辑器 官网文档:https://hufe.club/canvas-editor-docs/guide/schema.html 源码地址:https://github.com/Hufe921/canvas-editor 前提声明: 由于CanvasEditor目前不支持vue、react 等框架开箱即用版,所以需要我们去Git下载源码,拿到其中两个主

android一键分享功能部分实现

为什么叫做部分实现呢,其实是我只实现一部分的分享。如新浪微博,那还有没去实现的是微信分享。还有一部分奇怪的问题:我QQ分享跟QQ空间的分享功能,我都没配置key那些都是原本集成就有的key也可以实现分享,谁清楚的麻烦详解下。 实现分享功能我们可以去www.mob.com这个网站集成。免费的,而且还有短信验证功能。等这分享研究完后就研究下短信验证功能。 开始实现步骤(新浪分享,以下是本人自己实现

基于Springboot + vue 的抗疫物质管理系统的设计与实现

目录 📚 前言 📑摘要 📑系统流程 📚 系统架构设计 📚 数据库设计 📚 系统功能的具体实现    💬 系统登录注册 系统登录 登录界面   用户添加  💬 抗疫列表展示模块     区域信息管理 添加物资详情 抗疫物资列表展示 抗疫物资申请 抗疫物资审核 ✒️ 源码实现 💖 源码获取 😁 联系方式 📚 前言 📑博客主页:

探索蓝牙协议的奥秘:用ESP32实现高质量蓝牙音频传输

蓝牙(Bluetooth)是一种短距离无线通信技术,广泛应用于各种电子设备之间的数据传输。自1994年由爱立信公司首次提出以来,蓝牙技术已经经历了多个版本的更新和改进。本文将详细介绍蓝牙协议,并通过一个具体的项目——使用ESP32实现蓝牙音频传输,来展示蓝牙协议的实际应用及其优点。 蓝牙协议概述 蓝牙协议栈 蓝牙协议栈是蓝牙技术的核心,定义了蓝牙设备之间如何进行通信。蓝牙协议

vue同页面多路由懒加载-及可能存在问题的解决方式

先上图,再解释 图一是多路由页面,图二是路由文件。从图一可以看出每个router-view对应的name都不一样。从图二可以看出层路由对应的组件加载方式要跟图一中的name相对应,并且图二的路由层在跟图一对应的页面中要加上components层,多一个s结尾,里面的的方法名就是图一路由的name值,里面还可以照样用懒加载的方式。 页面上其他的路由在路由文件中也跟图二是一样的写法。 附送可能存在