配置OBS存储功能新搭建obs
Posted 源码全开
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了配置OBS存储功能新搭建obs相关的知识,希望对你有一定的参考价值。
通过应用开发环境与OBS(Object-based Storage Service)对接,实现对象或者Widget资产存储功能。
背景信息
对象存储服务(Object-based Storage Service,OBS)是一个基于对象的海量存储服务,为客户提供海量、安全、高可靠、低成本的数据存储能力,包括:创建、修改、删除桶,上传、下载、删除对象等。
在配置S3存储功能章节我们介绍过如何对接Amazon S3,本节将介绍如何对接OBS。
两者相同点如下:
- 两者对接的应用场景相同,都是为了实现对象或者Widget资产等的存储功能。
- 两者在应用开发环境上如何配置Connector的操作步骤相似。
两者差异点如下:
- 在对接Amazon S3时,您可以在Flow中调用Connector实现对接。
- 在对接OBS时,您只能通过调用应用开发环境的Rest接口来调用Connector实现对接。
场景描述
向OBS中存储“objectA.txt”文件。
前提条件
请获取如下关键信息:
- 已获取OBS用户的访问密钥 ID(Access key ID)和秘密访问密钥(Secret access key)。
- 已获取OBS服务的区域ID。
- 已在OBS上创建存储桶(例如“bing.testonly.1”),用于后续存储对象使用。
配置Connector操作步骤
- 在APP开发界面左侧列表单击,选择“连接 > 连接器”。
- 在Connectors配置界面中单击“OBS”图标,打开Connector列表。
- 单击“新建”。
- 输入与OBS对接的参数,单击“下一步”。图 1 新建Connector
表 1 新建Connector页面参数说明
参数 | 说明 |
---|---|
名称 | Connector的名称。示例: TestOBS |
访问密钥 | OBS用户的访问密钥 ID(Access key ID)。 |
密钥 | OBS用户的秘密访问密钥(Secret access key)。 |
账号地区 | OBS服务的区域ID。 |
内容分发网络 | CDN服务器的地址。通过该配置,您后续访问上传的静态资源时,可不用登录OBS,直接通过CDN访问到静态资源。可选配置。 |
描述 | Connector的描述信息。 |
5. 选择存储桶,用于选择在OBS上哪个存储桶上进行存储,也可选择多个桶进行存储,这里选择桶“bing.testonly.1”,单击“保存”。
6. (可选)创建Connector后,您可进行简单的测试,测试是否能在存储桶上存储对象。
说明:
该测试只能上传小于1MB字节的对象。
(1)在该Connector详情页面单击存储桶所在行的
。
(2)单击“点击上传”,选择对象文件,单击“上传”。
图 2 选择对象
(3)单击上传好的文件名,进行下载。打开下载的对象存储文件,查看与上传的对象存储文件是否一致。
调用Connector
1. 调用Rest接口,查询出Connector ID,根据Connector ID,才能调用具体的Connector。其中IP和Port分别是应用开发环境的IP地址和对外服务端口号。
http://IP:Port/u-route/baas/sys/v1.0/connectors?type=obs
该接口用于查询所有创建的OBS类型的Connector的ID。本示例中的查询结果中,找出Connector名称为“TestOBS”的Connector ID为“003W000000FfSV4F5twG”。接下来我们将根据这个ID,调用对接OBS的Connector“TestOBS”。
"resCode": "0",
"resMsg": "Success",
"result": [
"id": "003W000000FfSV4F5twG",
"name": "TestOBS",
"type": "obs",
"createdBy": "10gd000000En2xfeFqQy",
"createdDate": "2018-04-17 07:23:53",
"lastModifiedBy": "10gd000000En2xfeFqQy",
"lastModifiedDate": "2018-04-17 07:33:05",
"owner": "10gd000000En2xfeFqQy",
"accessKey": "0ZILHVIXUXXXXXXXXXX",
"secretKey": "O5ZeitY4dDQlCm4pJf8ow3BcoXXXXXXXXXX",
"rootRegion": "cn-south-1",
"buckets": [
"name": "bingo.testonly.1",
"region": "cn-south-1"
],
"createdBy.name": "Lily",
"lastModifiedBy.name": "Lily",
"owner.name": "Lily"
,
"id": "003W000000FfSYZ2NIHI",
"name": "TestB",
"type": "obs",
"createdBy": "10gd000000En2xfeFqQy",
"createdDate": "2018-04-17 07:24:41",
"lastModifiedBy": "10gd000000En2xfeFqQy",
"lastModifiedDate": "2018-04-17 07:24:41",
"owner": "10gd000000En2xfeFqQy",
"accessKey": "fdas",
"secretKey": "fdas",
"rootRegion": "fdsa",
"buckets": null,
"createdBy.name": "Lily",
"lastModifiedBy.name": "Lily",
"owner.name": "Lily"
]
2. 通过调用应用开发环境的Rest接口实现与OBS的对接。
Rest接口为:
http://IP:Port/u-route/baas/sys/v1.0/connectors/ConnectorID/action?type=obs&op=action&object=FileName&dir=DirName&bucket=BucketName
参数说明如下:
- IP:应用开发环境的IP地址。
- Port:应用开发环境对外提供服务的端口号。
- ConnectorID:该Connector ID。可通过上一步进行查询。
- action:具体的动作。如下:listbuckets:列举该存储桶上所有对象文件。putobject:上传对象文件。viewobject:查看对象文件。delobject:删除对象文件。createdir:在存储桶上创建文件目录。listdir:列举该文件目录下所有文件。deldir:删除目录。
- FileName:待存储到OBS上的文件名,请携带文件类型后缀。可选参数,根据接口动作进行携带。
- DirName:存储桶上的文件目录名。可选参数,根据接口动作进行携带。
- BucketName:存储桶名称。可选参数,根据接口动作进行携带。
例如查看存储桶“bingo.testonly.1”上存储对象文件“ObjectA.txt”的Rest接口为:
http://10.136.104.56:21112/u-route/baas/sys/v1.0/connectors/003W000000FfSV4F5twG/action?type=obs&op=viewobject&object=ObjectA.txt&bucket=bingo.testonly.1
搭建自己的直播流媒体服务器SRS,以及SRS+OBS直播推拉流使用及配置
一、前言
目前,全球直播带货什么的,成为主流,那如何自己搭建一个直播服务器呢。首先需要一个流媒体服务器,搭建流媒体有很多种方式,如下:
- 流媒体解决方案 Live555 (C++)
- 流媒体平台框架 EasyDarwin (C++,国产精品)
- 实时流媒体播放服务器程序DarwinStreamingSrvr (C++)
- Flash流媒体服务器 Red5 (Java)
- 流媒体服务器 Open Streaming Server (Java)
- FMS流媒体服务器 (Adobe,收费的)
- Wowza流媒体服务器(Java)
- 开源流媒体平台FreeCast(Java)
- Ngix+RTMP插件
- SRS+OBS
这里介绍国产开源流媒体服务器 SRS 的搭建及使用。
SRS简介
SRS(Simple Realtime Server)是一个简单高效的实时视频服务器, 是国人写的一款非常优秀的开源流媒体服务器软件,可用于直播/录播/视频客服等多种场景,其定位是运营级的互联网直播服务器集群。
支持RTMP/WebRTC/HLS/HTTP-FLV/SRT/GB28181。
官方网站:http://ossrs.net/lts/zh-cn/
目前版本为SRS4,属于稳定版,可用于生产环境
二、SRS安装
官方文档:http://ossrs.net/lts/zh-cn/docs/v4/doc/getting-started
安装主要有docker和源码安装,两种方式,都很简单。
官方推荐使用Docker启动SRS,这是最简单也是最方便的方式。
由于后续有些内容经常需要动到配置文件,所以我这里选择用源码安装的方式。
1:下载源码
git clone -b 4.0release https://gitee.com/ossrs/srs.git
2:编译,注意需要切换到srs/trunk目录
cd srs/trunk
./configure
make
3:启动服务器
./objs/srs -c conf/srs.conf
4:检查服务器状态
检查SRS是否成功启动,可以打开 http://localhost:8080/ ,如我这里服务器地址为:192.168.152.100。所以浏览器输入:http://192.168.152.100:8080/即可访问。
当然,也可以用命令检查服务器状态。
# 查看SRS的状态
./etc/init.d/srs status
# 或者看SRS的日志
tail -n 30 -f ./objs/srs.log
如下图,看到下面提示为正常启动。
SRS(pid 29588) is running. [ OK ]
三、OBS推流RTMP
推流可以选择FFmpeg或者OBS,如果对FFmpeg命令比较熟,可以选择这个,占用资源更少。
我这里选择OBS,因为界面话更友好直观。
OBS下载地址:https://obsproject.com/download
1:直播画面选择
在来源+中,选择要推送的画面,如果有摄像头或者摄像机,则添加“视频采集设备”,然后选择相应的摄像头名称即可。
我这里没摄像头,选择自己的电脑桌面直播推送,及“显示器采集”。
2:设置流媒体服务器
在右下方的 设置 >> 推流 >> 服务 >> 自定义。
填写流媒体服务器地址,我这里是: rtmp://192.168.152.100/live/
串流密钥随便填写即可,这里我填写的是:test-livestream。
所以最后播放地址为:rtmp://192.168.152.100/live/test-livestream
3:推送直播画面
配置完成后,点击 “开始推流” 即可推送画面。没有报错,说明推送成功,同时下方会有相关信息,如cpu之类的。
在浏览器 http://192.168.152.100:8080/ 打开控制台,可以看到推送的流信息。
点击预览,可以看到,刚才的推送画面了。后面加flv,是因为推流拉流都是用的RTMP。
所以RTMP流的播放地址为:rtmp://192.168.152.100/live/test-livestream.flv
4:VLC 播放器
VCL是一个很强大的播放器,支持播放网络串流。
所以可以直接用VCL播放测试。
下载地址:https://www.videolan.org/index.an.html
下载安装后,打开 媒体 >> 打开网络串流,输入播放地址即可观看直播画面。
四、RTMP低延时配置
以上基本的直播推流拉流,配置完成。但是测试,延迟还是很大。
根据直播画面和本地时间对比,可以发现延迟差不多有6秒左右,不是很正常。RTMP流,正常延迟时间为1到3秒左右,所以还需要配置。
1:默认配置文件
由于我们以默认的配置文件启动,即srs.conf 这个配置文件。默认配置文件如下:
ubuntu@ubuntu:~/srs/trunk$ cat conf/srs.conf
# main config for srs.
# @see full.conf for detail config.
listen 1935;
max_connections 1000;
#srs_log_tank file;
#srs_log_file ./objs/srs.log;
daemon on;
http_api
enabled on;
listen 1985;
http_server
enabled on;
listen 8080;
dir ./objs/nginx/html;
rtc_server
enabled on;
listen 8000; # UDP port
# @see https://ossrs.net/lts/zh-cn/docs/v4/doc/webrtc#config-candidate
candidate $CANDIDATE;
vhost __defaultVhost__
hls
enabled on;
http_remux
enabled on;
mount [vhost]/[app]/[stream].flv;
rtc
enabled on;
# @see https://ossrs.net/lts/zh-cn/docs/v4/doc/webrtc#rtmp-to-rtc
rtmp_to_rtc off;
# @see https://ossrs.net/lts/zh-cn/docs/v4/doc/webrtc#rtc-to-rtmp
rtc_to_rtmp off;
2:更改配置文件
根据官方文档,可以更改配置文件,低延迟配置,在vhost __ defaultVhost __ 添加以下配置。具体原理可以参考官方文档。
tcp_nodelay on;
min_latency on;
play
gop_cache off;
queue_length 10;
mw_latency 100;
publish
mr off;
最终配置文件为:
listen 1935;
max_connections 1000;
#srs_log_tank file;
#srs_log_file ./objs/srs.log;
daemon on;
http_api
enabled on;
listen 1985;
http_server
enabled on;
listen 8080;
dir ./objs/nginx/html;
rtc_server
enabled on;
listen 8000; # UDP port
# @see https://ossrs.net/lts/zh-cn/docs/v4/doc/webrtc#config-candidate
candidate $CANDIDATE;
vhost __defaultVhost__
hls
enabled on;
http_remux
enabled on;
mount [vhost]/[app]/[stream].flv;
rtc
enabled on;
# @see https://ossrs.net/lts/zh-cn/docs/v4/doc/webrtc#rtmp-to-rtc
rtmp_to_rtc off;
# @see https://ossrs.net/lts/zh-cn/docs/v4/doc/webrtc#rtc-to-rtmp
rtc_to_rtmp off;
tcp_nodelay on;
min_latency on;
play
gop_cache off;
queue_length 10;
mw_latency 100;
publish
mr off;
3:重载配置文件测试
配置完成后,reload重载配置,完成。
./etc/init.d/srs reload
然后再次用obs推流拉流,查看效果,延迟为2秒左右,在正常延迟范围内。
五、RTMP推流webRTC拉流(RTMP to RTC)
上面测试有2秒的延迟,有没有更低延迟呢。有,就是webRTC。
webRTC起初用于视频会议等及时通讯,现在越来越成熟,应用也越多,正常延迟为1秒之内。
1:更改配置文件
默认配置文件,有rtc的选项,是打开的,我们是RTMP to RTC,所以还需要把rtmp_to_rtc off 改成 rtmp_to_rtc on,即可。
rtc
enabled on;
# @see https://ossrs.net/lts/zh-cn/docs/v4/doc/webrtc#rtmp-to-rtc
rtmp_to_rtc on;
# @see https://ossrs.net/lts/zh-cn/docs/v4/doc/webrtc#rtc-to-rtmp
rtc_to_rtmp off;
还有重要的一点,rtc_server里的candidate配置。如果是服务器是云服务器之类的。必须将 $CANDIDATE 更改为公网IP,或者0.0.0.0(任何IP可访问)。我这里内网测试,所以无需更改。
rtc_server
enabled on;
listen 8000; # UDP port
# @see https://ossrs.net/lts/zh-cn/docs/v4/doc/webrtc#config-candidate
candidate $CANDIDATE;
2:重载配置测试
./etc/init.d/srs reload
由于vcl不支持webRTC格式串流,所以直接用控制台自动的webRTC播放器查看。
播放地址为:webrtc://192.168.152.100/live/test-livestream
同时打开直播画面和本地画面。
可以看到延迟在1秒之内,基本在500毫秒左右。
六、HLS流
HLS流,作为直播正常延迟10秒起步,所以也不推荐使用。如果要配置。
只需在默认配置文件中,添加如下即可,原来只有一行enabled on;
hls
enabled on;
hls_path ./objs/nginx/html;
hls_fragment 10;
hls_window 60;
重载配置后,可用vcl播放器地址:http://192.168.152.100:8080/live/test-livestream.m3u8
延迟太大,可自行测试。
七、DVR录制
OBS也可以直接录制,但是有些需求,需要在服务器上直接录制文件,如API需求,所以在服务器开启DVR即可。
1:更改配置文件
SRS支持将RTMP流录制成FLV或MP4文件。
DVR作为SRS3的核心功能,永远开启DVR,只需要在配置文件的
vhost defaultVhost 加入以下内容即可
dvr
enabled on;
dvr_apply all;
dvr_plan segment;
dvr_path ./objs/nginx/html/[app]/[2006]/[01]/[stream]-[02]-[15].[04].[05].[999].mp4;
dvr_duration 30;
dvr_wait_keyframe on;
time_jitter full;
参数说明:
- dvr_apply :DVR的apply决定了是否对某个流开启dvr,默认的all是对所有开启
- dvr_plan :可配置session和segment,session就是推流到停止推流为整段视频保存,dvr_duration参数不生效。segment为分段报错,和dvr_duration、dvr_wait_keyframe搭配使用。
- dvr_duration:录制每个片段时常,如30,为30秒一个片段。
- dvr_wait_keyframe:按关键帧切。
- time_jitter: 时间戳抖动算法。full使用完全的时间戳矫正;zero只是保证从0开始;off不矫正时间戳。
- dvr_path :文件报错路径及命令方式。
2:自定义DVR的路径和文件名
以上默认即可,主要参数: dvr_path 按自己需要改格式。
- 1:没有变量,SRS1.0方式(自动添加[stream].[timestamp].flv作为文件名):
dvr_path ./objs/nginx/html/[app]/[stream].[timestamp].flv;
#生成的文件名及路径:
./objs/nginx/html/live/livestream.1420254068776.flv;
- 2:按流和年月日分目录,时间作为文件名
dvr_path ./objs/nginx/html/[app]/[stream]/[2006]/[01]/[02]/[15].[04].[05].[999].flv;
#生成的文件名及路径:
./objs/nginx/html/live/livestream/2015/01/03/10.57.30.776.flv;
- 3:按流和年月分目录,日和时间作为文件名:
dvr_path ./objs/nginx/html/[app]/[stream]/[2006]/[01]/[02]-[15].[04].[05].[999].flv;
#生成的文件名及路径:
./objs/nginx/html/live/livestream/2015/01/03-10.57.30.776.flv;
- 4:按vhost/app和年月分目录,流名称、日和时间作为文件名:
dvr_path ./objs/nginx/html/[app]/[2006]/[01]/[stream]-[02]-[15].[04].[05].[999].flv;
#生成的文件名及路径:
./objs/nginx/html/live/2015/01/livestream-03-10.57.30.776.flv;
- 5:按app分目录,流和时间戳作为文件名(SRS1.0方式):
dvr_path ./objs/nginx/html/[app]/[stream].[timestamp].flv;
#生成的文件名及路径:
./objs/nginx/html/live/livestream.1420254068776.flv;
如果需要录制MP4格式的,就把flv后缀,改成mp4即可。
3:查看录制的文件
改成后重载配置
./etc/init.d/srs reload
过一段时间,可以在./objs/nginx/html/live/2022/09/ 看到生成的文件。
下载任意一个文件,播放可以看到录制的时间30秒左右。
4:Http Callback
服务器端定制的实现方式,就是HTTP回调。如需要api回调的方式获取dvr,在配置文件加入以下即可。
http_hooks
enabled on;
on_dvr http://127.0.0.1:8085/api/v1/dvrs;
更详细的可自行参考官方文档:HTTP Callback
八、小结
以上基本的使用及搭建就完成了,如果还需要功能可自行参考官方文档。
引用官方的那句话:
对于新手来说,音视频的门槛真的非常高,SRS的目标是降低(不能消除)音视频的门槛,所以请一定要读完Wiki:https://ossrs.net/lts/zh-cn/docs/v4/doc/introduction
以上是关于配置OBS存储功能新搭建obs的主要内容,如果未能解决你的问题,请参考以下文章
编译基于obs-studio的阿里巴巴直播工具tblive的过程和常见问题解决
搭建自己的直播流媒体服务器SRS,以及SRS+OBS直播推拉流使用及配置
搭建自己的直播流媒体服务器SRS,以及SRS+OBS直播推拉流使用及配置