【SRS】流媒体服务器(推流+拉流+转流)

前言

课程作业需要搭建一个视频流服务器,最初我采用的是HLS推流方式,发现那延迟卡的我一愣一愣的,这主要还是由于HLS需要等待切片完成。那行吧,那就换一个吧,一番周折后遇到了SRS(Simple RTMP Server)似乎还不错的样子(国人的骄傲),其集成了多种流媒体服务器,就是环境有点对在家的我有点小难受,win系统的笔记本的我叫我如何是好。阿里云对学生有优惠,我就租了,其实不租也行,装个虚拟机内网穿透一下也同样好使。
对rtmp/http-flv/hls这三种协议剖析,大佬这篇理解RTMP、HttpFlv和HLS的正确姿势写的还是挺赞的

安装

环境ubuntu16.04
github源码主页:https://github.com/ossrs/srs
我就直接用了release版:wget https://github.com/ossrs/srs/archive/v4.0.23.zip

unzip v4.0.23.zip
cd srs-4.0.23/trunk/
./configure
make

编译完之后可以执行make install,默认是安装到/usr/local/srs
配置文件:/usr/local/srs/conf/rtmp.conf
listen 6666;
max_connections 1000;
daemon off;
srs_log_tank console;
vhost defaultVhost {
}
其中listen默认为1935,是rtmp流推送的默认端口;max_connections值最大连接;daemon是否为守护进行在后台执行,vhost的主要作用:(1)支持多用户:当一台服务器需要服务多个客户(即内容分发网络CDN有多个客户),隔离访问的资源。(2)域名调度:CDN分发内容时,需要让用户访问离自己最近的边缘节点,边缘节点再从源站或上层节点获取数据,达到加速访问的效果。一般的做法就是Host是DNS域名,这样可以根据用户的信息解析到不同的节点。
这里的__defaultVhost__对应本地服务器公网IP

在安装路径/usr/local/srs下启动服务器:./objs/srs -c conf/rtmp.conf,启动成功便可向服务器推流了
PS:端口占用检查 netstat -ap | grep 6666

推流

推流采用win下的OBS软件
在这里插入图片描述串流密匙拉流时:服务器url/串流密匙
win下OBS选择流源,并开始推流,云服务器出现如下标识推流成功
在这里插入图片描述

拉流

通常我们会有VLC播放器进行拉流,可是云服务器有一点让人很头疼:界面化操作太卡,捉急的是VLC还不支持命令行启动。得亏这次是公网IP,可以远程拉流。就在本地win浏览器中的测试网站上验证一下吧。
在这里插入图片描述

转流

SRS支持将RTMP流转封装为HTTP flv流,即在publish发布RTMP流时,在SRS的http模块中挂载一个对应的http地址(根据配置),用户在访问这个http flv文件时,从rtmp流转封装为flv分发给用户。
配置文件 /usr/local/srs/conf/rtmp.conf 中添加:
http_server {
enabled on;
listen 8080; #http服务器的监听端口
}

vhost defaultVhost {
#分发flv流
http_remux {
enabled on;
mount [vhost]/[app]/[stream].flv;
}
}

重新运行rtmp,开始推流后你会有如下发现在这里插入图片描述

SRS(Simple Rtmp Server)的定位是运营级的互联网直播服务器集群,追求更好的概念完整性和最简单实现的代码。 • 运营级: 商业运营追求极高的稳定性,良好的系统对接,以及错误排查和处理机制。譬如日志文件格式,reload,系统HTTP接口,提供init.d脚本,转发,转码,边缘回多源站,都是根据CDN运营经验作为判断这些功能作为核心的依据。 • 互联网: 互联网最大的特征是变化,唯一不变的就是不断变化的客户要求,唯一不变的是基础结构的概念完整性和简洁性。互联网还意味着参与性,听取用户的需求和变更,持续改进和维护。 • 直播服务器: 直播和点播这两种截然不同的业务类型,导致架构和目标完全不一致,从运营的设备组,应对的挑战都完全不同。两种都支持只能说明没有重心,或者低估了代价。 • 集群: FMS(AMS)的集群还是很不错的,虽然在运营容错很差。SRS(Simple Rtmp Server)支持完善的直播集群,Vhost分为源站和边缘,容错支持多源站切换、测速、可追溯日志等。 • 概念完整性: 虽然代码甚至结构都在变化,但是结构的概念完整性是一直追求的目标。从SRS(Simple Rtmp Server)服务器,P2P,ARM监控产业,MIPS路由器,服务器监控管理,ARM智能手机,SRS(Simple Rtmp Server)的规模不再是一个服务器而已。 • 简单实现: 对于过于复杂的实现,宁可不加入这个功能,也不牺牲前面提到的要求。对于已经实现的功能的代码,总会在一个版本release前给予充分的时间来找出最简答案。不求最高性能,最优雅,最牛逼,但求最简单易懂。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

星空•物语

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值