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

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

一、目标

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. html5适应屏幕的方案

          适应屏幕的方案: 1.css3 Media queries (针对多版本设计稿) 2.设计稿不复杂的时候 通过宽度自适应用百分比 3.通过更新meta:viewport标签,通过设计稿尺寸 ...

  2. 利用大数据技术处理海量GPS数据

    我秀中国物联网地图服务平台目前接入的监控车辆近百万辆,每天采集GPS数据7亿多条,产生日志文件70GB,使用传统的数据处理方式非常耗时. 比如,仅仅对GPS做一些简单的统计分析,程序就需要几个小时才能 ...

  3. 分享知识-快乐自己:FastDFS详解

    在使用fdfs之前,需要对其有一定的了解,这篇文章作为准备篇,将针对fdfs的简介,功能性,使用场景等方面进行介绍 一):起源 淘宝网开放平台技术部资深架构师余庆先生首先回顾了自己在Yahoo工作时的 ...

  4. mysql数据库(二):查询(SELECT)

    一. 数据库查询—查询(SELECT) 单表查询 多表联合查询 二. 查询—单表查询 查询特定字段: select <字段1,字段2,...> from <表名>; 示例:查询 ...

  5. http Code含义

    5xx - 服务器错误 服务器由于遇到错误而不能完成该请求.

  6. 32-THREE.JS 球体

    <!DOCTYPE html> <html> <head> <title>Example 05.05 - Basic 3D geometries - S ...

  7. Python基础学习(第8天)

    先补充些iter函数的用法:iter()其实就是一个迭代器,参数可传个list.dict等等,然后可通过调用next函数获取下一个元素,默认并未指向对象的第一个元素,可理解为指向了第一个元素的前面的位 ...

  8. JS 页面加载触发事件 document.ready和onload的区别

    document.ready和onload的区别——JavaScript文档加载完成事件页面加载完成有两种事件: 一是ready,表示文档结构已经加载完成(不包含图片等非文字媒体文件): 二是onlo ...

  9. 理解 HTTP2.0

    链接 HTTP/2 头部压缩技术介绍 我们知道,HTTP/2 协议由两个 RFC 组成: 一个是 RFC 7540,描述了 HTTP/2 协议本身:一个是 RFC 7541,描述了 HTTP/2 协议 ...

  10. padding和margin的用法

    在CSS中margin是指从自身边框到另一个容器边框之间的距离,就是容器外距离.在CSS中padding是指自身边框到自身内部另一个容器边框之间的距离,就是容器内距离. 一.padding 1.语法结 ...