zoukankan      html  css  js  c++  java
  • Ubuntu下用nginx和nginx-rtmp-module搭建流媒体服务器

    前言:

    公司要新开一个与视频直播相关的游戏的坑。首先需要解决的问题就是:如何实现流媒体直播,是采用现在比较成熟的各种云直播方案,还是自己搭建视频服务器。由于后续运营可能面对国外市场,采用国内的云,意味着前期需要学习相关的sdk接入,然后在此基础上进行的开发最后却可能完全用不上。因此决定先自己搭建一个流媒体服务器进行前期开发,最后再决定实际运营采用哪一个云,或者干脆就用自己的服务器也未可知。总之,我们需要快速搭建一个流媒体服务器以便迅速展开开发工作。

    1.下载nginx-rtmp-module:

    nginx-rtmp-module的官方github地址:https://github.com/arut/nginx-rtmp-module
    使用命令:

    git clone https://github.com/arut/nginx-rtmp-module.git

    下载的内容放到~/prog目录下。

    2.安装nginx:

    机器原来已经用sudo apt install装好了nginx。

    nginx -v
    nginx version: nginx/1.10.0 (Ubuntu)

    因为要配置增加模块,安装好的版本没法玩,卸载了吧。

    sudo apt remove nginx

    nginx的官方网站为:http://nginx.org/en/download.html

    下载最新的稳定版本1.12.0,解压到~/prog下面。
    进入到nginx 1.12.0的目录下,配置一下:

    ./configure --add-module=../nginx-rtmp-module --with-http_flv_module --with-http_mp4_module

    考虑后期可能有需要播放flv,mp4的需求,加上相关模块。
    吐槽:起先用配置--prefix=/home/myfolder把nginx安装到本地用户目录下,以为可以避开一些权限问题,少用几次sudo。没想到开启80端口,记录log什么的还是要权限,所以还是安装到默认的系统目录下吧。sudo是debian和ubuntu的特点,习惯就好。

    报了这样一个错:

    ./configure: error: the HTTP rewrite module requires the PCRE library.
    You can either disable the module by using --without-http_rewrite_module
    option, or install the PCRE library into the system, or build the PCRE library
    statically from the source with nginx by using --with-pcre=<path> option.

    意思就是HTTP rewrite模块需要PCRE 库,要么你加个不要这个模块的选项重新配置nginx,要么就安装PCRE。当然必须选择安装PCRE。

    sudo apt install libpcre3 libpcre3-dev

    系统报告libpcre3早就装好了,其实只需要装开发库libpcre3-dev。
    重新配置,这次报告是需要OpenSSL,继续装:

    sudo apt install openssl libssl-dev

    系统报告openssl早就装好了,已经是最新版本了,想来还是跟PCRE一样,只需要装个开发库。

    再次配置,成功。接下来就是编译安装。因为要装到系统目录下,make install前面要加sudo

    make
    sudo make install

    修改配置项后,为安全起见,记得用make clean清理一下,然后再make

    3.配置nginx:

    sudo vim /usr/local/nginx/conf/nginx.conf

    在最后加入:

    rtmp {
    
        server {
            listen 1935;  #监听的端口
    
            chunk_size 4000;
    
            application hls {  #rtmp推流请求路径  
                live on;
                hls on;
                hls_path /usr/local/nginx/html/hls;
                hls_fragment 5s;
             }    
        }    
    }  
    

    这里的视频流目录 hls_path设置为 /usr/local/nginx/html/hls,这个目录的权限用chmod设置为775。

    原来的http中加入下面配置的server部分:

    http {  
      
        server {  
      
            listen  8080;  
              
            location /stat {    
                rtmp_stat all;    
                rtmp_stat_stylesheet stat.xsl;    
            }    
      
            location /stat.xsl {    
                root /usr/local/src/nginx-rtmp-module/;    
            }    
              
            location /control {    
                rtmp_control all;    
            }    
      
            location /hls {  
                # Serve HLS fragments  
                types {  
                    application/vnd.apple.mpegurl m3u8;  
                    video/mp2t ts;  
                }  
                root html;  
                expires -1;  
            }  
    
            location ~.flv {
                flv;
            }
            location ~.mp4$ {
                mp4;
            }
        }  
    }  
    

    进入/usr/local/nginx目录下,键入sudo ./sbin/nginx就可以启动。相关命令用-s参数发信号,-s后跟stop,quit,reopen,reload等可以停止/推出/重新开启/重新加载

    推流测试

    Windows或者linux都可以用OBS做直播推流测试,一款非常好的免费开源直播软件。
    官网:https://obsproject.com/

    现在最新版本18.0.1,有官方中文版,自动识别的。视频来源可以选显示器捕获或者窗口捕获,以本机屏幕上的内容推送到先前配置好的流媒体服务器上。

    可以看到服务器上的hls目录下有一个以你指定名字命名的后缀为m3u8的文件和其他不断实时生成流媒体文件。用safari浏览器可以直接打开这个m3u8文件观看直播视频。其他浏览器需要插件,下文再谈。



    另:可能遇到的依赖:

    apt-get install gcc g++
    apt-get install libpcre3 libpcre3-dev
    apt-get install zlib1g zlib1g.dev
    apt-get install openssl libssl-dev

  • 相关阅读:
    java 项目的CAS搭建
    OpenStack Grizzly版本(Ubuntu 12.04)配置
    存储介质管理
    软件包管理
    终端和键盘
    Shell环境(environment)和配置(configuration)
    Linux 基本命令入门
    iptables的原理及使用
    移动小球 (sicily 1934) (双向链表)
    1010 Tempter of the Bone (杭电) (图Graph)
  • 原文地址:https://www.cnblogs.com/surplus/p/12629972.html
Copyright © 2011-2022 走看看