利用nginx与nginx-rtmp-module搭建流媒体服务器实现直播

使用环境是centos 7.0+nginx;可以实现简单的流媒体服务。

先下载nginx-rtmp-module拓展:

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

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

先将nginx-rtmp-module下载到linux服务器中,如果没有git需先安装git,参考linux安装git

 

接下来安装nginx

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

1
2
3
4
5
wget http: //nginx .org /download/nginx-1 .8.1. tar .gz 
tar  -zxvf nginx-1.8.1. tar .gz 
cd  nginx-1.8.1 
. /configure  --prefix= /usr/local/nginx   --add-module=.. /nginx-rtmp-module   --with-http_ssl_module   
make  &&  make  install

默认安装目录为:/root, add-module为下载的nginx-rtmp-module文件路径。如果没有wget要先安装wget组件

 

安装时候可能会报错没有安装openssl,需要先安装openssl:

1
yum -y  install  openssl openssl-devel

 

安装好nginx后修改nginx配置文件

1
vi  /usr/local/nginx/conf/nginx .conf

 

在配置文件中加入RTMP部分

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
rtmp {   
     
     server {   
     
         listen 1935;   #监听的端口 
     
         chunk_size 4000;   
           
            
         application hls {   #rtmp推流请求路径 
             live on;   
             hls on;   
             hls_path  /usr/share/nginx/html/hls ;   
             hls_fragment 5s;   
         }   
     }   

其中hls_path文件夹必须要有写入的权限

 

再修改http中的server模块:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
server { 
     listen       81;     #拉流请求的端口号
     server_name  localhost; 
   
     #charset koi8-r; 
   
     #access_log  logs/host.access.log  main; 
   
     location / { 
         root    /usr/share/nginx/html ;    #跟目录文件夹
         index  index.html index.htm; 
    
   
     #error_page  404              /404.html; 
   
     # redirect server error pages to the static page /50x.html 
    
     error_page   500 502 503 504   /50x .html; 
     location =  /50x .html { 
         root   html; 
     }

root可以跟据自己的需求来改的。

然后启动nginx:

1
/usr/local/nginx/sbin/nginx  -c  /usr/local/nginx/conf/nginx .conf 

 

关于更多rtmp的参数可以参考官方文档

 

配置好服务器后就可以开始推流了,这里暂时用开源的obs软件进行简单推流

 

在设置->串流 中填写信息:URL为 rtmp://xxx:1935/hls,xxx为你的服务器的IP地址,hls是在流媒体服务器中用来存放流媒体的文件夹。

秘钥可以随便填写一个,用来播放的时候识别播放哪个流媒体的,例如填写test等

填写完毕后,点击开始串流,就说明我们的流媒体服务器搭建成功,这里推流会把流媒体文件推送到服务器文件夹内,生成一个test.m3u8流媒体文件。

 

推流成功后开始拉流(观看直播)

Html5自带的video标签就可以观看

1
2
3
<video>   
     < source  src= "http://xxx:81/hls/test.m3u8" />
< /video

在IOS下的safar浏览器直接可以观看,安卓和winows系统下可能需要借助播放器观看。

不过直播的延迟比较高,这是因为服务器将视频流切断成一个个小的以.ts结尾的文件,我们访问的是.m3u8文件,这个文件内容是将一个个ts文件串联起来的,这就达到了一个播放的效果,所以看起来会有很大的延迟。

如果降低延迟也不是没有方法,可以设置切片生成的大小以及访问的速度,但是这样大大增加了服务器的压力。

当然,我们也可以用rtmp拉流工具(VLC等)来看该直播,拉流地址与推流地址一致,这样能减少延迟。

要考虑具体情况要保持延迟和服务器压力间的均衡。

 

最后要注意的是,拉流时,如果在其他服务器使用播放器请求流媒体服务器的文件,会涉及到跨域。

这时候要在流媒体服务器root目录下加入 crossdomain.xml 文件,文件内容为

1
2
3
4
<?xml version= "1.0"  encoding= "utf-8" ?>
<cross-domain-policy>
     <allow-access-from domain= "*" />   这里可设置允许请求的域名
< /cross-domain-policy >

 

以上就可以完成一个简单的流媒体服务,进行直播。

 

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值