随身WIFI折腾日记(五)---远程视频监控

news2025/1/13 2:35:06

六、远程视频监控

为了实现基于随身WIFI的网络摄像头,我参考了如下视频课程:

  • 韦东山老师手把手带你从0开始自己做一个视频监控项目

image-20230522103303312

image-20230522155036408

系统由三部分组成:推流端(随身WIFI)、流媒体服务器(云服务器)、拉流端(浏览器/VLC播放器)

方案:在云服务器端基于docker部署Nginx-RTMP Server平台。然后使用ffmpeg开源工具将USB摄像头的视频流推送到云服务器上,最后简单开发一个前端界面在浏览器端拉取视频流/或者使用VLC播放器直接打开rtmp地址播放视频。

6.1 插入摄像头

image-20230523223117303

把USB摄像头插入到USB拓展坞上,我的摄像头是同淘宝随便买的,带麦克风1080p的自动对焦摄像头。(USB拓展坞供电使用功率大一点的充电头,1A的充电头带不动USB摄像头

  1. 使用以下命令在Debian系统中安装lsusb工具:

    sudo apt-get install usbutils
    
  2. 输入以下命令查看系统中已连接的USB设备列表:

    lsusb
    
  3. 如果您的摄像头已经被正确地连接到系统上,那么命令会输出一个关于USB摄像头的信息,包括制造商和设备ID等信息。我打印出来的信息如下:

    Bus 001 Device 003: ID 090c:1000 Silicon Motion, Inc. - Taiwan (formerly Feiya Technology Corp.) Flash Drive
    Bus 001 Device 004: ID 0c45:636b Microdia USB 2.0 Camera
    Bus 001 Device 002: ID 05e3:0610 Genesys Logic, Inc. Hub
    Bus 001 Device 001: ID 1d6b:0002 Linux Foundation 2.0 root hub
    
  4. 使用 pacmd list-sources 命令查看当前可用的音频输入设备,可查看到我的音频设备号是device.string = "hw:1"

  5. 使用 ls /dev命令打印所有设备节点,可以看到在插入摄像头后,多了video3j节点,作为摄像头的设备节点是/dev/video3

6.2 配置流媒体服务器

现有的rtmp服务器方案有很多,我采用nginx-rtmp服务器去接受和处理视频流。

github开源地址:arut/nginx-rtmp-module

使用docker 快速部署到我的云服务器上。

docker run -it -p 1935:1935 -p 8080:80 --rm alfg/nginx-rtmp 
#-v ./nginx.conf:/etc/nginx/nginx.conf   自定义配置文件参数

推流的默认地址:

rtmp://your-rtmp-server:1935/stream/视频流名称

视频流的默认访问地址:

rtmp://your-rtmp-server:1935/stream/视频流名称
https://your-rtmp-server:8080/hls/视频流名称.m3u8
https://your-rtmp-server:8080/live/视频流名称.m3u8

服务器视频流统计数据访问地址:

http://your-rtmp-server:8080/stat

image-20230523173213900

6.3 FFmpeg推流

参考链接:

  • 视音频编解码技术零基础学习方法

  • ffmpeg 基本用法

FFmpeg 是一个开源的跨平台的音视频处理工具,可以处理音频、视频等多媒体格式。它可以将音频、视频等多媒体文件进行编解码、转码、剪辑等操作,并且具有非常强大的功能和扩展性,被广泛应用于音视频处理领域。

FFmpeg也可以使用多种推流协议来进行推流,例如 RTMP、RTSP、HLS、UDP 等。我们可以使用命令行可以轻松对音视频进行处理,包括提取音频、视频、封装成相应格式、加密等操作。

  1. 首先在随身WIFI上安装FFmpeg ,需要占用330M的存储空间还是挺大的,需要安装一段时间。

  2. 使用推流到云服务器的1935端口:

    ffmpeg -f v4l2 -video_size 640x480 -framerate 25 -i /dev/video2 -f alsa -ac 1 -r 8000 -i hw:1,0 -c:v libx264 -b:v 100k -maxrate 100k -bufsize 1000k -preset veryfast -tune zerolatency -c:a aac -b:a 8k -f flv rtmp://twinbee.cn/stream/webcam 
    
参数含义参数含义
-f v4l2设置输入设备为v4l2摄像头-ac音频通道数
-video_size设置视频画面的大小-r设置音频采样率
-framerate设置帧率-i hw:1,0设置音频输入设备的位置
-i /dev/video2设置视频输入设备的位置-c:v libx264设置视频编码器为 H.264
-f alsa设置音频输入设备为alsa-b:v指定视频的平均比特率
-c:a aac设置音频编码器为 AAC-maxrate指定视频的最大比特率
-b:a指定音频的比特率-bufsize指定视频的缓冲区大小
-f flv设置输出格式为 FLV-preset指定视频编码的预设值
rtmp://twinbee.cn/stream/webcam指定推流地址-tune指定视频编码的优化参数

其中webcam是我们自定义的视频流的名称,stream是nginx-rtmp服务器默认配置的应用名(可通过配置文件修改)。

6.4 VLC播放器播放

在VLC播放器中–媒体–打开网络串流,输入我们配置好的地址:

rtmp://twinbee.cn/stream/webcam

启动:

image-20230522224844019

6.5 网页端显示

目前流行的视频流协议:

协议http-flvrtmphls
传输方式http流tcp流http流
视频封装格式flvflvTs文件
延迟
数据分段连续流连续流切片文件
h5播放flv.jsvideo.jshls.js

我们刚刚使用VLC软件rtmp协议拉取视频流。在网页端,rtmp视频流播放需要浏览器flash支持,但是2020年底所有浏览器不再支持flash插件之后,rtmp的视频流就不能在浏览器中播放了。这个时候可以采用将rtmp重新封装成http-flv的视频流,采用flv.js来进行播放。

a.重新配置RTMP服务器

github地址:https://github.com/winshining/nginx-http-flv-module

nginx-rtmp服务器并不支持http-flv输出,所以需要重新配置为nginx-http-flv 服务器。其是一款基于 nginx-rtmp-module 的流媒体服务器,支持http-flv输出,相当于nginx-rtmp升级版。

使用docker一键部署:

docker run --rm -it -p 8080:80 -p 1935:1935 mugennsou/nginx-http-flv

docker的部署说明文档:http-flv/README_CN.md at master · mugennsou/http-flv · GitHub

其配置文件中默认的应用名称为demo

所以rtmp推流的地址为:

rtmp://your-rtmp-server:1935/demo/视频流名称

视频流的访问地址:

http://your-rtmp-server:8080/live?app=demo&stream=视频流名称

b.重新推流

ffmpeg -f v4l2 -video_size 640x480 -framerate 25 -i /dev/video2 -f alsa -ac 1 -r 8000 -i hw:1,0 -c:v libx264 -b:v 100k -maxrate 100k -bufsize 1000k -preset veryfast -tune zerolatency -c:a aac -b:a 8k -f flv rtmp://twinbee.cn/demo/webcam 

http-flv在线测试地址:http://bilibili.github.io/flv.js/demo/ (不需要flash插件)

使用上述网站测试推流地址,推流成功!

image-20230523184031836

c.H5前端界面

写一个简单的HTML界面,部署在我的个人wordpress网站页面上。

<!DOCTYPE html>
<html>
<head>
    <meta charset="UTF-8">
    <title>HTTP-FLV 播放器</title>
    <!-- 引入 flv.js 库 -->
    <script src="https://cdn.bootcdn.net/ajax/libs/flv.js/1.5.0/flv.min.js"></script>
</head>
<body>
    <video id="videoPlayer" controls></video>
    <script>
        if (flvjs.isSupported()) {
            // 配置播放器
            var videoPlayer = document.getElementById('videoPlayer');
            var flvPlayer = flvjs.createPlayer({
                type: 'flv',
                // 指定 HTTP-FLV 流 URL
                url: 'http://twinbee.cn:8080/live?app=demo&stream=webcam'
            });
            flvPlayer.attachMediaElement(videoPlayer);
            flvPlayer.load();
            flvPlayer.play();
        }
    </script>
</body>
</html>

image-20230523185809423

画面有10s左右的延迟。还不太知道为什么。

浏览器不支持flash插件之后,h5播放rtmp直播流的解决方案

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

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

相关文章

NetworkInterface类

文章目录 1. 简介2. 工厂方法3. 获取方法 1. 简介 NetworkInterface类表示一个本地IP地址。这可以是一个物理接口&#xff0c;如额外的以太网卡&#xff08;常见于防火墙和路由器&#xff09;&#xff0c;也可以是一个虚拟接口&#xff0c;与机器的其它IP地址绑定到同个物理硬…

ensp实践dhcp服务

ensp实践dhcp服务 1、dhcp接口分配模式2、dhcp接口地址池分配模式3、dhcp布拉布拉布拉 1、dhcp接口分配模式 1.1、路由器AR1配置dhcp动态获取 <Huawei>system-view [Huawei]interface g0/0/0 [Huawei-GigabitEthernet0/0/0]ip address 10.1.1.1 24 [Huawei-GigabitEthe…

PixiJS 源码解读:绘制矩形,底层都做了什么?

大家好&#xff0c;我是前端西瓜哥&#xff0c;今天带大家看一下 PixiJS 的源码实现。 PixiJS 是一个非常流行的 Canvas 库&#xff0c;start 数将近 4w。 使用 PixiJS 简单易用的 API&#xff0c;我们可以在浏览器页面的 Canvas 元素上高性能地绘制图形&#xff0c;实现流畅…

基于深度学习的交通标志检测和识别(从原理到环境配置/代码运行)

项目是一个基于Python和OpenCV的交通标志检测和识别项目,旨在使用计算机视觉和深度学习技术对交通标志进行检测和分类。本文将从介绍项目原理和框架开始,详细介绍该项目的实现过程和技术细节,最后给出项目的安装和使用方法。 前后结果对比 识别前 识别后 一、 项目原理和框…

随身WIFI折腾日记(一)---霓虹灯

引言 通过对高通410芯片的随身WIFI刷写Debain系统&#xff0c;我们已经拥有了一台带4G功能的迷你ARM64单板电脑。现在我们可以基于此此平台进行一下二次开发。 随身WIFI的优势就是价格低廉&#xff0c;性能和树莓派zero2、树莓派3b差不多。 硬件配置如下&#xff1a; msm89…

随身WIFI折腾日记(二)---文件传输和软件安装

二、文件传输 我们可以通过SCP和SFTP工具和随身WIFI(USB连接)进行数据传输&#xff0c;上图以scp工具为例。 将本地电脑文件传输至随身WIFI&#xff0c;本地电脑上输入如下指令即可&#xff1a; scp /path/to/local/file user192.168.68.1:/path/to/remote/directory/注意&…

RK3568平台开发系列讲解(驱动基础篇)10min带你获取、了解与编译Kernel源代码

🚀返回专栏总目录 文章目录 一、Kernel获取二、Kernel根目录2.1 Documentation/2.1 arch/2.2 block/2.3 boot.its2.4 drivers/2.5 firmware/2.6 fs/2.7 include/2.8 init/2.9 ipc/2.10 kernel/2.11 lib/2.12 lo

(转载)从0开始学matlab(第13天)—画图进阶

我们将讨论简单的二维图象(之前已有所介绍)的附加特性。这些特性将允许我们控制 x&#xff0c;y 轴上的值的范围&#xff0c;在一个坐标系内打印多个图象&#xff0c;或创建多个图&#xff0c;或在一个图象窗口内创建多个子图像&#xff0c;或提供更加强大的轨迹文本字符控制。…

【c语言】全部知识点总结

创作不易&#xff0c;本篇文章如果帮助到了你&#xff0c;还请点赞 关注支持一下♡>&#x16966;<)!! 主页专栏有更多知识&#xff0c;如有疑问欢迎大家指正讨论&#xff0c;共同进步&#xff01; 给大家跳段街舞感谢支持&#xff01;ጿ ኈ ቼ ዽ ጿ ኈ ቼ ዽ ጿ ኈ ቼ …

前端如何做单元测试? 看这篇就入门了

前言 对于现在的前端工程&#xff0c;一个标准完整的项目&#xff0c;通常情况单元测试是非常必要的。但很多时候我们只是完成了项目而忽略了项目测试。我认为其中一个很大的原因是很多人对单元测试认知不够&#xff0c;因此我写了这边文章&#xff0c;一方面期望通过这篇文章…

基于DDSRF正负序分离方法的不平衡电网PQ控制策略_平衡电流控制

0.前言 对于并网逆变器而言&#xff0c;电网会存在不平衡的情况。在这种情况下&#xff0c;不平衡的电网电压可以分解成为正序、负序和零序分量。并网逆变器通常期望能够实现单位功率因数并网&#xff0c;向电网注入对称的正弦电流&#xff0c;所以此时的微电网逆变器控制策略显…

DC-9靶机-简单谈一下端口敲门技术 (Port Knocking)

前言 在打靶机DC-9时&#xff0c;爆破SSH时一直显示失败&#xff0c;经过查阅才知道原来是对端口做了“隐藏”&#xff0c;需要通过 Port Knocking 来主动开启&#xff0c;由于平时接触到的机会不多&#xff0c;所以这里简单记录一下&#xff0c;加强一下印象&#xff0c;也希…

Systrace系列7 —— Vsync 解读

本文主要是是介绍 Android 中的 Vsync 机制。文章会从 Systrace 的角度来看 Android 系统如何基于 Vsync 每一帧的展示。Vsync 是 Systrace 中一个非常关键的机制,虽然我们在操作手机的时候看不见,摸不着,但是在 Systrace 中我们可以看到,Android 系统在 Vsync 信号的指引下…

Tomcat系统架构浅析

大家好&#xff0c;我是易安&#xff01; 今天咱们就来一步一步分析Tomcat的设计思路&#xff0c;看看Tomcat的设计者们是如何设计一个复杂系统&#xff0c;怎么设计顶层模块&#xff0c;以及模块之间的关系。 Tomcat总体架构 我们知道如果要设计一个系统&#xff0c;首先是要…

特征缩放(Scale Features)、特征缩放预测​CO2 值、df列索引扩展

目录 1、特征缩放 2、预测CO2 值 3、df列索引扩展 1、特征缩放 特征缩放可以用于不同的度量单位。度量单位不同的情况下&#xff0c;特征的数值大小也会有所不同&#xff0c;这可能会影响到某些机器学习算法的表现。例如&#xff0c;如果一个特征的单位是英寸&#xff0c;而另…

DAB-DETR代码学习笔记

先上一张整体架构图 &#xff1a; 代码地址&#xff1a;GitHub - IDEA-Research/DAB-DETR: [ICLR 2022] DAB-DETR: Dynamic Anchor Boxes are Better Queries for DETR 论文地址&#xff1a; https://arxiv.org/pdf/2201.12329.pdf 文章全名《DYNAMIC ANCHOR BOXES ARE BETTER …

建模杂谈系列223 Q-Learning示例的代码拆解分析

说明 找到了一个合适的例子&#xff0c;然后我对其中的内容进行了拆解分析。我觉得代码表达的内容比伪代码清晰多了。 这次算是补砖了(监督无监督强化)&#xff0c;过去实际上接触过很多强化体系内的基本工具&#xff0c;但一直没有开始做&#xff0c;部分原因是没时间&#…

Java 与排序算法(5):归并排序

一、归并排序 归并排序&#xff08;Merge Sort&#xff09;是一种基于分治思想的排序算法。它将待排序的数组分成两个长度相等的子数组&#xff0c;然后对这两个子数组分别进行归并排序&#xff0c;最后将两个排好序的子数组合并成一个有序的数组。 具体实现过程如下&#xf…

【国内chatgpt使用方法合集】(5月22日已更新)

写在前面 Hello大家好&#xff0c; 我是【麟-小白】&#xff0c;一位软件工程专业的学生&#xff0c;喜好计算机知识。希望大家能够一起学习进步呀&#xff01;本人是一名在读大学生&#xff0c;专业水平有限&#xff0c;如发现错误或不足之处&#xff0c;请多多指正&#xff0…

Elasticsearch文档操作:初学者指南(2023年最新版包含DSL语句的使用和RestHighLevelClient在Java中的使用)

2023年还没有学习Elasticsearch?&#xff0c;那么您将错过最强大、最通用的编程语言之一。 本文将介绍在Elasticsearch对文档分别使用DSL语句和Java High Level REST ClientAPI来对文档进行操作。获取更多信息查看官网帮助文档 运行环境&#xff1a; Linux&#xff0c;docke…