查看: 157|回复: 4

[原创] 【BPI-M2Berry试用】搭建直播服务器平台

[复制链接]

5

主题

0

好友

143

积分

童生

Rank: 2

该用户从未签到

发表于 2017-10-7 16:26:16 |显示全部楼层
本帖最后由 ky123 于 2017-10-9 09:52 编辑

目录
1、准备
2、编译
3、配置

4、推流、拉流



一、准备

下载ngnix服务器源码
  1. wget http://nginx.org/download/nginx-1.13.5.tar.gz
复制代码
下载rtmp模块
  1. git clone https://github.com/arut/nginx-rtmp-module.git
复制代码
安装依赖
  1. sudo apt-get install openssl libssl-dev
  2. sudo apt-get install libpcre3 libpcre3-dev
  3. sudo apt-get install zlib1g-dev  
复制代码
准备工作差不多到这里结束
二、编译
解压nginx源码,并进入该目录
进行配置
  1. ./configure --prefix=/usr/local/nginx  --add-module=../nginx-rtmp-module  --with-http_ssl_module   
复制代码
159.png
  1. make && sudo make install
复制代码
因为需要写文件到/usr/local目录下,因此安装命令需要sudo权限,
安装完成了,接下来开始配置直播服务器
三、配置
rtmp是直播推流采用的协议,因此这里以rtmp推流、拉流的过程做个示范
更改配置文件,
  1. nano /usr/local/nginx/conf/nginx.conf
复制代码
这里给出我的配置文件,修改的地方已用+++++++++++++++++++标出
  1. #user  nobody;
  2. worker_processes  1;

  3. #error_log  logs/error.log;
  4. #error_log  logs/error.log  notice;
  5. #error_log  logs/error.log  info;

  6. #pid        logs/nginx.pid;


  7. events {
  8.     worker_connections  1024;
  9. }


  10. http {
  11.     include       mime.types;
  12.     default_type  application/octet-stream;

  13.     #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
  14.     #                  '$status $body_bytes_sent "$http_referer" '
  15.     #                  '"$http_user_agent" "$http_x_forwarded_for"';

  16.     #access_log  logs/access.log  main;

  17.     sendfile        on;
  18.     #tcp_nopush     on;

  19.     #keepalive_timeout  0;
  20.     keepalive_timeout  65;

  21.     #gzip  on;

  22.     server {
  23.         listen       80;
  24.         server_name  localhost;

  25.         #charset koi8-r;

  26.         #access_log  logs/host.access.log  main;

  27.         location / {
  28.             root   html;
  29.             index  index.html index.htm;
  30.         }

  31.        #+++++++++++++++++++
  32.        location /carlpc_hls  {
  33.             types{
  34.                 application/vnd.apple.mpegurl m3u8;
  35.                 video/mp2t ts;
  36.             }
  37.             alias  /home/pi/hls;
  38.             expires -1;
  39.         }
  40.      # +++++++++++++++++++


  41.         #error_page  404              /404.html;

  42.         # redirect server error pages to the static page /50x.html
  43.         #
  44.         error_page   500 502 503 504  /50x.html;
  45.         location = /50x.html {
  46.             root   html;
  47.         }

  48.         # proxy the PHP scripts to Apache listening on 127.0.0.1:80
  49.         #
  50.         #location ~ \.php$ {
  51.         #    proxy_pass   http://127.0.0.1;
  52.         #}

  53.         # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
  54.         #
  55.         #location ~ \.php$ {
  56.         #    root           html;
  57.         #    fastcgi_pass   127.0.0.1:9000;
  58.         #    fastcgi_index  index.php;
  59.         #    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
  60.         #    include        fastcgi_params;
  61.         #}

  62.         # deny access to .htaccess files, if Apache's document root
  63.         # concurs with nginx's one
  64.         #
  65.         #location ~ /\.ht {
  66.         #    deny  all;
  67.         #}
  68.     }


  69.     # another virtual host using mix of IP-, name-, and port-based configuration
  70.     #
  71.     #server {
  72.     #    listen       8000;
  73.     #    listen       somename:8080;
  74.     #    server_name  somename  alias  another.alias;

  75.     #    location / {
  76.     #        root   html;
  77.     #        index  index.html index.htm;
  78.     #    }
  79.     #}


  80.     # HTTPS server
  81.     #
  82.     #server {
  83.     #    listen       443 ssl;
  84.     #    server_name  localhost;

  85.     #    ssl_certificate      cert.pem;
  86.     #    ssl_certificate_key  cert.key;

  87.     #    ssl_session_cache    shared:SSL:1m;
  88.     #    ssl_session_timeout  5m;

  89.     #    ssl_ciphers  HIGH:!aNULL:!MD5;
  90.     #    ssl_prefer_server_ciphers  on;

  91.     #    location / {
  92.     #        root   html;
  93.     #        index  index.html index.htm;
  94.     #    }
  95.     #}

  96. }
  97. #+++++++++++++++++++
  98. rtmp {   
  99.      
  100.     server {   
  101.      
  102.         listen 1935;
  103.           publish_time_fix on;
  104.         chunk_size 4000;   
  105.            

  106.         application carlpc{
  107.                 live on;
  108.                 allow publish all; # control access privilege
  109.              allow play all; # control access privilege
  110.         }
  111.             
  112.         application carlpc_hls {  
  113.             live on;   
  114.             hls on;   
  115.             hls_path /home/pi/hls;   
  116.             hls_fragment 5s;  
  117.                 allow publish all;
  118.                 allow play all;
  119.         }   
  120.     }   
  121. }
  122. #+++++++++++++++++++
复制代码
配置完成后,第一次启动nginx
  1. /usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
复制代码
再一执行上条命令可以看到以下端口已绑定
2017-10-07_15-50-01.gif

四、推流、拉流
推流方式,有三种
1、OBS推流

2、FMLE推流

135.png

3、FFMPEG推流



为了方便,直接使用obs进行推流,那有个问题是推流的地址是啥呢?
根据上面的配置文件rtmp采用端口1935,并且配置了两个发布点carlpc和carlpc_hls,一个是用来rtmp推流拉流,一个则是rtmp推流后经过切片,以hls的协议进行拉流。
因此,两个发布点的推流地址为(test为自定义的流名)
  1. rtmp://192.168.137.21:1935/carlpc

  2. rtmp://192.168.137.21:1935/carlpc_hls/test
复制代码
=============================================
rtmp推流、拉流
178.png

设置后进行推流,接着进行拉流
拉流地址与推流地址一样

456.png

=====================================================
rtmp推流,hls拉流
17.png


这里拉流地址与推流地址不一样了,配置中可以看到,要想通过此拉流,需要走http协议的80端口,来读取/home/pi/hls目录下的切片文件,因此拉流地址使用的端口是80端口。
先通过观看/home/pi/hls是否有切片文件
2017-10-07_162148.png

那怎么读取这些文件呢?比如要读取第4个切片文件就可以通过以下URL进行读取
  1. http://192.168.137.21:80/carlpc_hls/test-4.ts
复制代码
2017-10-07_162300.png

最后,祝大家双节快乐,今天先写这些啦
回复

使用道具 举报

18

主题

6

好友

2866

积分

超级版主

Rank: 8Rank: 8

该用户从未签到

发表于 2017-10-7 19:10:13 |显示全部楼层
挤挤 ,明天是节日的最后一天,小尾巴
回复

使用道具 举报

5

主题

0

好友

143

积分

童生

Rank: 2

该用户从未签到

发表于 2017-10-7 20:06:45 |显示全部楼层
ky123 发表于 2017-10-7 19:10
挤挤 ,明天是节日的最后一天,小尾巴

今天发个帖,让可依觉得我天天都在发帖
回复

使用道具 举报

3

主题

1

好友

3880

积分

状元

Rank: 6Rank: 6

  • TA的每日心情
    奋斗
    昨天 22:14
  • 签到天数: 894 天

    连续签到: 9 天

    [LV.10]以坛为家III

    发表于 2017-10-8 21:41:26 |显示全部楼层
    参考和学习
    回复

    使用道具 举报

    18

    主题

    6

    好友

    2866

    积分

    超级版主

    Rank: 8Rank: 8

    该用户从未签到

    发表于 2017-10-9 08:55:05 |显示全部楼层
    手手挤挤 发表于 2017-10-7 20:06
    今天发个帖,让可依觉得我天天都在发帖

    哈哈哈,你说的对
    早呀
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    关闭

    站长推荐上一条 /5 下一条

    手机版|爱板网 |网站地图  

    GMT+8, 2017-10-23 12:05 , Processed in 0.258083 second(s), 17 queries , Memcache On.

    苏公网安备 32059002001056号

    Powered by Discuz!

    回顶部