这是自己搭建直播服务器、开发直播平台系列的文章,前面两篇文章分别为:

这篇文章是在上面多频道输入输出和权限控制的基础上进行的。

一、目标

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实现直播状态、观看人数控制的更多相关文章

  1. 实时监控、直播流、流媒体、视频网站开发方案流媒体服务器搭建及配置详解:使用nginx搭建rtmp直播、rtmp点播、,hls直播服务配置详解

    注意:这里不会讲到nginx流媒体模块如何安装的问题,只研究rtmp,hls直播和录制相关的nginx服务器配置文件的详细用法和说明.可以对照这些命令详解配置nginx -rtmp服务 一.nginx ...

  2. 「自己开发直播」实现nginx-rtmp-module多频道输入输出与权限控制

    之前写了一篇文章,利用nginx和nginx-rtmp-module实现直播. 不过,之前只是做到了能够直播而已,只能一个人推流,并没有实现多人多频道输入输出,也没有权限控制,只要知道rtmp的URL ...

  3. 这款 IDE 插件再次升级,让「小程序云」的开发部署提速 8 倍

    今年3月份,在阿里云北京峰会上,阿里巴巴正式发布了“阿里巴巴小程序繁星计划”,截至当前,已经有成千上万的开发者加入这个计划,使得小程序得到蓬勃发展,然而不可避免的是,这些服务加重了对云端的开发部署.运 ...

  4. 「查缺补漏」巩固你的Nginx知识体系

    Nginx篇 基本介绍 Nginx是一款轻量级的 Web服务器 / 反向代理服务器 / 电子邮件(IMAP/POP3)代理服务器,主要的优点是: 支持高并发连接,尤其是静态界面,官方测试Nginx能够 ...

  5. 抛开flash,自己开发实现C++ RTMP直播流播放器

    抛开flash,自己开发实现C++ RTMP直播流播放器 众所周知,RTMP是以flash为客户端播放器的直播协议,主要应用在B/S形式的场景中.本人研究并用C++开发实现了RTMP直播流协议的播放器 ...

  6. Android流媒体开发之路二:NDK开发Android端RTMP直播推流程序

    NDK开发Android端RTMP直播推流程序 经过一番折腾,成功把RTMP直播推流代码,通过NDK交叉编译的方式,移植到了Android下,从而实现了Android端采集摄像头和麦克缝数据,然后进行 ...

  7. 微信小程序开发平台新功能「云开发」快速上手体验

    微信小程序开发平台刚刚开放了一个全新的功能:云开发. 简单地说就是将开发人员搭建微信小程序后端的成本再次降低,此文刚好在此产品公测时,来快速上手看看都有哪些方便开发者的功能更新. 微信小程序一直保持一 ...

  8. 「Android 开发」入门笔记

    「Android 开发」入门笔记(界面编程篇) ------每日摘要------ DAY-1: 学习笔记: Android应用结构分析 界面编程与视图(View)组件 布局管理器 问题整理: Andr ...

  9. 实战开发一个Nginx扩展 (Nginx Module)

    repo地址 https://github.com/wujunze/nginx-http-echo-module nginx_module_echo 使用echo指令输出一个字符串 Nginx 版本 ...

随机推荐

  1. QT treewidget 右键菜单

    VS2012+QT5.2 ,没有ui,纯代码实现右键 方法一:常规但略麻烦 1.头文件slot中声明 QTreeWidget *tree; void showrightMenu(QPoint);//显 ...

  2. Ajax-02 iframe实现伪“Ajax”

    需求: 用户输入URL,使用iframe将目标URL的内容加载到页面指定位置(局部刷新) <!DOCTYPE html> <html lang="en"> ...

  3. jmeter导入jar包后在beanshell中import失效的问题解决

    最近一直很忙,没有时间来更新了,今天抽空把之前遇到的问题记录下来. 之前在使用jmeter做http请求性能压测时,因为要对所有入参做排序再加密作为一个入参,所以写了一段java代码,用来处理入参,打 ...

  4. 百度之星2017初赛A-1005-今夕何夕

    今夕何夕 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submis ...

  5. DOCKER实战案例

    操作系统:[root@yz6205 ~]# docker search busyboxNAME DESCRIPTION STARS OFFICIAL AUTOMATEDbusybox Busybox ...

  6. monkey 原理,环境搭建、命令详解

    一.monkey测试的相关的原理 monkey测试的原理就是利用socket通讯的方式来模拟用户的按键输入,触摸屏输入,手势输入等,看设备多长时间会出异常.当Monkey程序在模拟器或设备运行的时候, ...

  7. redis memcache rabbitMQ

    Python之路[第九篇]:Python操作 RabbitMQ.Redis.Memcache.SQLAlchemy Memcached Memcached 是一个高性能的分布式内存对象缓存系统,用于动 ...

  8. CSS: transitions

    CSS Transitions CSS transitions allows you to change property values smoothly (from one value to ano ...

  9. margin特性深入分析与总结

    今天写了个小demo,总体不难,但一些细节需要注意: 1)如下图所示,蓝色区域为白色box的padding,橙色区域为每条数据项的margin-bottom,那么如何解决最后一条记录margin-bo ...

  10. 小晚wan的公众号

    转载请注明出处:http://blog.csdn.net/dongdong9223/article/details/70932630 本文出自[我是干勾鱼的博客] 小晚wan的公众号还是挺深刻的,有时 ...