前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >ubuntu搭建推流服务器Nginx+rtmp

ubuntu搭建推流服务器Nginx+rtmp

作者头像
AlicFeng
发布2018-06-08 14:56:01
4K0
发布2018-06-08 14:56:01
举报

****前言**** 最近这两年直播平台及其流行,然而我呢? 也要玩玩推流服务器~~~ 实现服务器推流/PC客户端观看/浏览器客户端查看


****简介**** 对于Nginx的优点呢就不多说了,两句话: 1)并发量高 2)可负载均衡 重点谈谈rtmp吧! RTMP全称是Real Time Messaging Protocol(实时消息传输协议),rmtp是一种通讯协议。该协议基于TCP,是一个协议族,包括RTMP基本协议及RTMPT/RTMPS/RTMPE等多种变种。RTMP是一种设计用来进行实时数据通信的网络协议,主要用来在Flash/AIR平台和支持RTMP协议的流媒体/交互服务器之间进行音视频和数据通信。现在更流行于直播平台服务器的推流处理!


****install搭建****

  • 建立源码编译的目录
代码语言:javascript
复制
$ mkdir nginx-src
$ cd nginx-src
  • 下载源码仓库
代码语言:javascript
复制
#nginx源码
$ git clone https://github.com/nginx/nginx.git
#nginx的rtmp模块源码
$ git clone https://github.com/arut/nginx-rtmp-module.git
#nginx的依赖pcre源码
$ wget ftp://ftp.csx.cam.ac.uk/pub/software/programming/pcre/pcre-8.39.tar.gz
$ tar -xzvf pcre-8.39.tar.gz
$ cd nginx$ git checkout release-1.9.9
  • 准备编译安装
代码语言:javascript
复制
#将configure的命令封装成脚本
$ vim cfg.sh
代码语言:javascript
复制
#  cfg.sh文件的内容
auto/configure --prefix=/usr/local/nginx \
        --with-pcre=../pcre-8.39 \
                --with-http_ssl_module \
                --with-http_v2_module \
                --with-http_flv_module \
                --with-http_mp4_module \
                --add-module=../nginx-rtmp-module/
代码语言:javascript
复制
$ chmod a+x cfg.sh
$ ./cfg.sh
$ make 
$ make install
  • 启动nginx服务器
代码语言:javascript
复制
/usr/local/nginx/sbin/nginx

****配置nginx**** 在nginx的配置文件nginx.conf最后添加如下信息

代码语言:javascript
复制
# RMTP的服务器配置信息
rtmp {
        server {
                listen  2016; #推流的监听端口
                publish_time_fix on;
                # 推流其一
                application live {
                        live on; #stream on live allow
                        allow publish all; # control access privilege
                        allow play all; # control access privilege
                }
               #推流其二
        application hls_alic {
                        live on;
                        hls on;
                        hls_path /home/alic/www/hls;
                        hls_fragment 5s;
                }
        }
}

重新加载nginx的配置

代码语言:javascript
复制
$ /usr/local/nginx/sbin/nginx -s reload

****简单的测试demo**** 安装ffmpag

代码语言:javascript
复制
$ add-apt-repository ppa:kirillshkrogalev/ffmpeg-next
$ apt-get update
$  apt-get install ffmpeg

使用ffmpeg向服务器推送一个视频

代码语言:javascript
复制
ffmpeg -re -i /home/alic/Desktop/demo/film.mp4 -c copy -f flv rtmp://localhost:2016/live/film
or
# 推荐 可用于浏览器播放
ffmpeg -re -i /home/alic/Desktop/demo/film.mp4 -c copy -f flv rtmp://localhost:2016/hls_alic/film

Alic_推流

视频播放器获取视频流

Alic_客户端获取流

对于浏览器呢,html的整理代码如下

代码语言:javascript
复制
<html>
<head>
    <link rel="stylesheet" href="http://vjs.zencdn.net/5.10/video-js.css">
</head>
    <video id=example-video width=960 height=540 class="video-js vjs-default-skin" controls>
        <source
            src="film.m3u8"
            type="application/x-mpegURL">
    </video>
    <script src="http://vjs.zencdn.net/5.10/video.js"></script>
    <script src="https://npmcdn.com/videojs-contrib-hls@^3.0.0/dist/videojs-contrib-hls.js"></script>
    <script>
        var player = videojs('example-video');
        player.play();
    </script>
</html>

注意,在hls_path的路径添加一个站点来访问即可! 推流还是用ffmpeg的命令来, 推流一段时间后, 你会发现在"/home/alic/www/hls"目录里, 有很多ts文件, 还有一个后缀".m3u8"文件上面配置中的 server:8081 块, 就是为了能在外部能访问这些ts文件和m3u8文件。

Alic_浏览器

搭建推流服务器Nginx+rtmp就成功了! 即将总结ffmpeg推流的命令~~~


本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2016.09.05 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云直播
云直播(Cloud Streaming Services,CSS)为您提供极速、稳定、专业的云端直播处理服务,根据业务的不同直播场景需求,云直播提供了标准直播、快直播、云导播台三种服务,分别针对大规模实时观看、超低延时直播、便捷云端导播的场景,配合腾讯云视立方·直播 SDK,为您提供一站式的音视频直播解决方案。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档