oracle直播,利用Simple-RTMP-Server搭建RTMP和HLS直播服务(上)

SRS(Simple-RTMP-Server)定位是运营级的互联网直播服务器集群,追求更好的概念完整性和最简单实现的代码,在Github上人气颇高。本文是由王学投稿的SRS搭建直播的学习笔记,由LiveVideoStack整理并首发。

文 / 王学

整理 / LiveVideoStack

文章共6个部分,涉及SRS采集 、编码、录制、传输、解码等整套解决方案。

下载和编译SRS

利用OBS推流RTMP到SRS

从RTSP镜头拉取流到SRS

SRS demo 运行

SRS流程简单分析

SRS支持将RTMP流录制成flv文件

一、下载和编译SRS

官方地址:https://github.com/ossrs/srs

tar -zxvf srs-2.0-r2.tar.gz

cd srs-2.0-r2

./configure --with-ssl --with-hls --with-nginx --with-ingest --with-ffmpeg --with-transcode –demo

make

注意:官方说需要关闭防火墙和selinux

二、利用OBS推流和用VLC播放

1、推流地址:rtmp://192.168.43.118:1935/live/livestream

6f7df2c777b407a512c50af02b46af63.png

确定后,开始推流。由于设置了HLS分发,所以在Nginx目录下(./objs/nginx/html/live)会有m3u8/ts。ts文件的长度和个数是根据配置文件的hls_fragment和hls_window属性配置出来,详细请参看:https://github.com/ossrs/srs/wiki/v2_CN_DeliveryHLS

2、使用默认的配置文件hls.conf

listen              1935;

max_connections     1000;

vhost __defaultVhost__ {

hls {

enabled         on;

hls_path  ./objs/nginx/html;

hls_fragment    10;

hls_window      60;

}

}

hls配置节(hls分发)

enabled:是否开启HLS

hls_fragment:指定ts切片的最小长度(单位:秒)

hls_window:指定HLS大小,即m3u8中ts文件的时长之和,超过总时长后,丢弃第一个m3u8中的第一个切片,直到ts的总时长在这个配置项范围之内。即SRS保证下面的公式:hls_window>= sum(m3u8中每个ts的时长)

详细说明:https://github.com/ossrs/srs/wiki/v2_CN_DeliveryHLS

#启动分发hls(m3u8/ts)的nginx

./objs/nginx/sbin/nginx

#启动srs服务

./objs/srs -c ./conf/hls.conf

3、用VLC来播放HLS或RTMP

19bc4c6e93364ec293e543e26757706a.png

RTMP播放地址:rtmp://192.168.43.118:1935/live/livestream

HLS播放地址:http://192.168.43.118/live/livestream.m3u8

三、从RTSP镜头拉取流到SRS

手机作为RTSP摄像头,安装EasyIPCamera。感谢EasyDarwin提供这个好用的工具。

rtsp://192.168.43.49:852021年04月13日1708

#启动srs服务

./objs/srs -c ./conf/ingest.conf

1、使用默认的配置文件ingest.conf

# use ffmpeg to ingest file/stream/device to SRS

# @see https://github.com/ossrs/srs/wiki/v1_CN_SampleIngest

# @see full.conf for detail config.

listen              1935;

max_connections     1000;

daemon              off;

srs_log_tank        console;

vhost __defaultVhost__ {

ingest livestream {

enabled      on;

input {

type    stream;

url     rtsp://192.168.43.49:852021年04月13日1708;

}

ffmpeg      ./objs/ffmpeg/bin/ffmpeg;

engine {

enabled          off;

output          rtmp://127.0.0.1:[port]/live?vhost=[vhost]/livestream2;

}

}

}

2、用VLC来播放RTMP

e35d2be24d5b0c5d09753a4d44880ab7.png

四、SRS demo 运行

启动srs 服务器 ./scripts/run.sh

启动SRS转发服务器成功

停止srs 服务器 ./scripts/stop.sh

访问http://192.168.43.118:8085

0ad40267abccd37b0265865c255f4cc1.png

五、SRS流程分析

8d781e396c0057d3766573a6520b867d.png

六、SRS支持将RTMP流录制成flv文件

待续。有兴趣你也可一试,走进流媒体领域。加油!

关于作者

王学,目前就职于东方网力,早期进入北海通信,对音视频领域的研发产生了极大的兴趣,在嵌入式板子上研究ffplay(当时FFmpeg还是0.9.x版本)。后进入安防领域,从事安防平台服务器端Linux C++开发工作,也喜欢研究服务器端高并发、高可靠性的实现。

1aaa43d3acd615b2270ce8088f0f0a10.png

LiveVideoStack招募社区编辑

LiveVideoStack是专注在音视频、多媒体开发的技术社区,通过传播最新技术探索与应用实践,帮助技术人员成长,解决企业应用场景中的技术难题。如果你有意为音视频、多媒体开发领域发展做出贡献,欢迎成为LiveVideoStack社区编辑的一员。你可以翻译、投稿、采访、提供内容线索等。

通过contribute@livevideostack.com联系,或在LiveVideoStack公众号回复『社区编辑』了解详情。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
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
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值