设为首页 收藏本站
查看: 1154|回复: 0

[经验分享] 利用nginx与nginx-rtmp

[复制链接]

尚未签到

发表于 2017-12-22 23:16:07 | 显示全部楼层 |阅读模式
  使用环境是centos 7.0+nginx;可以实现简单的流媒体服务。
  先下载nginx-rtmp-module拓展:
  nginx-rtmp-module的官方github地址:https://github.com/arut/nginx-rtmp-module
  

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
  

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:
  

yum -y install openssl openssl-devel  

  

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

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

  

  在配置文件中加入RTMP部分
  

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模块:
  

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:
  

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

  

  关于更多rtmp的参数可以参考官方文档
  配置好服务器后就可以开始推流了,这里暂时用开源的obs软件进行简单推流
DSC0000.png

  在设置->串流 中填写信息:URL为 rtmp://xxx:1935/hls,xxx为你的服务器的IP地址,hls是在流媒体服务器中用来存放流媒体的文件夹。
  秘钥可以随便填写一个,用来播放的时候识别播放哪个流媒体的,例如填写test等
  填写完毕后,点击开始串流,就说明我们的流媒体服务器搭建成功,这里推流会把流媒体文件推送到服务器文件夹内,生成一个test.m3u8流媒体文件。
  推流成功后开始拉流(观看直播)
  Html5自带的video标签就可以观看
  

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

  

  在IOS下的safar浏览器直接可以观看,安卓和winows系统下可能需要借助播放器观看。
  不过直播的延迟比较高,这是因为服务器将视频流切断成一个个小的以.ts结尾的文件,我们访问的是.m3u8文件,这个文件内容是将一个个ts文件串联起来的,这就达到了一个播放的效果,所以看起来会有很大的延迟。
  如果降低延迟也不是没有方法,可以设置切片生成的大小以及访问的速度,但是这样大大增加了服务器的压力。
  当然,我们也可以用rtmp拉流工具(VLC等)来看该直播,拉流地址与推流地址一致,这样能减少延迟。
  要考虑具体情况要保持延迟和服务器压力间的均衡。
  最后要注意的是,拉流时,如果在其他服务器使用播放器请求流媒体服务器的文件,会涉及到跨域。
  这时候要在流媒体服务器root目录下加入 crossdomain.xml 文件,文件内容为
  

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

  

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

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-427007-1-1.html 上篇帖子: windows下搭建nginx服务器及实现nginx支持https配置流程 下篇帖子: Nginx负载均衡中后端节点服务器健康检查的操作梳理
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表