「自己开发直播」rtmp-nginx-module实现直播状态、观看人数控制
这是自己搭建直播服务器、开发直播平台系列的文章,前面两篇文章分别为:
这篇文章是在上面多频道输入输出和权限控制的基础上进行的。
一、目标
1、实现直播状态的更改:
(直播状态的更改主要是为了显示,在前端刷新列表的时候,用于判断那些直播间在直播,哪些不在。):
- 用户开始推流之后,操作数据库,更改直播状态,显示直播间已经开始直播。
- 用户推流结束或者关闭软件后,操作数据库,更改直播状态。
2、实现简单的人数统计(暂用):
这里实现人数统计是基于数据库的(rtmp-nginx-module本身是有一个模块的,可以实现当前视频流观看人数的统计),这里只是简单的实现自增和自减数据库。
- 用户观看打开页面开始观看直播,数据库字段自增1
- 用户关闭页面后,连接断掉,数据库字段自减1
二、rtmp服务器的配置
在 实现nginx-rtmp-module多频道输入输出与权限控制 这篇文章里,我们配置了 on_publish 这个参数。
主要实现多频道和权限控制,用户在正式推流到服务器之前首先去配置的url中验证一下权限(具体的可以看上篇文章)。
目前我们需要配置更多的参数:
application myapp{
live on; # live on表示开启直播模式
on_publish http://192.168.124.125/on_publish.html;
on_publish_done http://192.168.124.125/on_publish_done.html;
on_play http://192.168.124.125/on_play.html;
on_play_done http://192.168.124.125/on_play_done.html;
}
可以看到,除了 on_publish ,我们还配置了 on_publish_done、on_play、on_play_done 三个参数,后面也是一个url。
这三个参数也是非常容易理解的,分别对应如下:
- on_publish_done —— 推流结束
- on_play —— 客户端播放
- on_play_done —— 客户端播放结束
对上面三个参数的具体解释和用法可以看rtmp的文档:
经过上面的配置,用户推送或者推送结束、或者用户播放和播放结束都能够触发URL,同时操作数据库即可。
三、程序部分注意问题
配置好了URL,就需要进行操作,但是会发现一个问题:
- 不知道用户观看的是哪个流、或者不知道推送结束的是哪个流
上面问题可以看 实现nginx-rtmp-module多频道输入输出与权限控制 这篇文章里面接收的 name参数 ,上面的配置中所有的推送都会携带一个name参数,而这个name是不可变的,用于标识当前流名称。
用我写的简单举个例子:
- 下面是基于thinkphp5框架写的。
- url与函数不匹配是因为我做了route。
可以看到,每次的操作都会获得一个name的参数,当然,除了name之外每个不同的配置有不同的参数可以获取,具体可以去 文档 了解一下
/**
* 用户直播结束的回调事件
* - 用户直播结束后,将status设置成0,标注该房间未在推流
* @param Request $request
*/
function onPublishDone(Request $request){
// 获得stream name
$name=trim($request->param('name'));
// 关闭直播 设置status 为 0
Db::name('room')->where(['guid'=>$name])->setField('status',0);
return json('')->code(200)->header(['关闭直播']);
}
/**
* 用户观看直播的回调事件
*/
function onPlay(Request $request){
// 获得视频流地址
$name=trim($request->param('name'));
// 有人加入观看,设置people +1
Db::name('room')->where(['guid'=>$name])->setInc('people');
}
/**
* 用户结束观看直播的回调事件
* @param Request $request
*/
function onPlayDone(Request $request){
// 获得视频流地址
$name=trim($request->param('name'));
// 有人加入观看,设置people -1
Db::name('room')->where(['guid'=>$name])->setDec('people');
}
「自己开发直播」rtmp-nginx-module实现直播状态、观看人数控制的更多相关文章
- 实时监控、直播流、流媒体、视频网站开发方案流媒体服务器搭建及配置详解:使用nginx搭建rtmp直播、rtmp点播、,hls直播服务配置详解
注意:这里不会讲到nginx流媒体模块如何安装的问题,只研究rtmp,hls直播和录制相关的nginx服务器配置文件的详细用法和说明.可以对照这些命令详解配置nginx -rtmp服务 一.nginx ...
- 「自己开发直播」实现nginx-rtmp-module多频道输入输出与权限控制
之前写了一篇文章,利用nginx和nginx-rtmp-module实现直播. 不过,之前只是做到了能够直播而已,只能一个人推流,并没有实现多人多频道输入输出,也没有权限控制,只要知道rtmp的URL ...
- 这款 IDE 插件再次升级,让「小程序云」的开发部署提速 8 倍
今年3月份,在阿里云北京峰会上,阿里巴巴正式发布了“阿里巴巴小程序繁星计划”,截至当前,已经有成千上万的开发者加入这个计划,使得小程序得到蓬勃发展,然而不可避免的是,这些服务加重了对云端的开发部署.运 ...
- 「查缺补漏」巩固你的Nginx知识体系
Nginx篇 基本介绍 Nginx是一款轻量级的 Web服务器 / 反向代理服务器 / 电子邮件(IMAP/POP3)代理服务器,主要的优点是: 支持高并发连接,尤其是静态界面,官方测试Nginx能够 ...
- 抛开flash,自己开发实现C++ RTMP直播流播放器
抛开flash,自己开发实现C++ RTMP直播流播放器 众所周知,RTMP是以flash为客户端播放器的直播协议,主要应用在B/S形式的场景中.本人研究并用C++开发实现了RTMP直播流协议的播放器 ...
- Android流媒体开发之路二:NDK开发Android端RTMP直播推流程序
NDK开发Android端RTMP直播推流程序 经过一番折腾,成功把RTMP直播推流代码,通过NDK交叉编译的方式,移植到了Android下,从而实现了Android端采集摄像头和麦克缝数据,然后进行 ...
- 微信小程序开发平台新功能「云开发」快速上手体验
微信小程序开发平台刚刚开放了一个全新的功能:云开发. 简单地说就是将开发人员搭建微信小程序后端的成本再次降低,此文刚好在此产品公测时,来快速上手看看都有哪些方便开发者的功能更新. 微信小程序一直保持一 ...
- 「Android 开发」入门笔记
「Android 开发」入门笔记(界面编程篇) ------每日摘要------ DAY-1: 学习笔记: Android应用结构分析 界面编程与视图(View)组件 布局管理器 问题整理: Andr ...
- 实战开发一个Nginx扩展 (Nginx Module)
repo地址 https://github.com/wujunze/nginx-http-echo-module nginx_module_echo 使用echo指令输出一个字符串 Nginx 版本 ...
随机推荐
- html5适应屏幕的方案
适应屏幕的方案: 1.css3 Media queries (针对多版本设计稿) 2.设计稿不复杂的时候 通过宽度自适应用百分比 3.通过更新meta:viewport标签,通过设计稿尺寸 ...
- 利用大数据技术处理海量GPS数据
我秀中国物联网地图服务平台目前接入的监控车辆近百万辆,每天采集GPS数据7亿多条,产生日志文件70GB,使用传统的数据处理方式非常耗时. 比如,仅仅对GPS做一些简单的统计分析,程序就需要几个小时才能 ...
- 分享知识-快乐自己:FastDFS详解
在使用fdfs之前,需要对其有一定的了解,这篇文章作为准备篇,将针对fdfs的简介,功能性,使用场景等方面进行介绍 一):起源 淘宝网开放平台技术部资深架构师余庆先生首先回顾了自己在Yahoo工作时的 ...
- mysql数据库(二):查询(SELECT)
一. 数据库查询—查询(SELECT) 单表查询 多表联合查询 二. 查询—单表查询 查询特定字段: select <字段1,字段2,...> from <表名>; 示例:查询 ...
- http Code含义
5xx - 服务器错误 服务器由于遇到错误而不能完成该请求.
- 32-THREE.JS 球体
<!DOCTYPE html> <html> <head> <title>Example 05.05 - Basic 3D geometries - S ...
- Python基础学习(第8天)
先补充些iter函数的用法:iter()其实就是一个迭代器,参数可传个list.dict等等,然后可通过调用next函数获取下一个元素,默认并未指向对象的第一个元素,可理解为指向了第一个元素的前面的位 ...
- JS 页面加载触发事件 document.ready和onload的区别
document.ready和onload的区别——JavaScript文档加载完成事件页面加载完成有两种事件: 一是ready,表示文档结构已经加载完成(不包含图片等非文字媒体文件): 二是onlo ...
- 理解 HTTP2.0
链接 HTTP/2 头部压缩技术介绍 我们知道,HTTP/2 协议由两个 RFC 组成: 一个是 RFC 7540,描述了 HTTP/2 协议本身:一个是 RFC 7541,描述了 HTTP/2 协议 ...
- padding和margin的用法
在CSS中margin是指从自身边框到另一个容器边框之间的距离,就是容器外距离.在CSS中padding是指自身边框到自身内部另一个容器边框之间的距离,就是容器内距离. 一.padding 1.语法结 ...