配置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操作步骤

  1. 在APP开发界面左侧列表单击,选择“连接 > 连接器”。
  2. 在Connectors配置界面中单击“OBS”图标,打开Connector列表。
  3. 单击“新建”。
  4. 输入与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直播推拉流使用及配置

2021-12-09 spring boot 集成 华为云obs

什么是华为云对象存储OBS?它有什么优势?

Windows+nginx+rtmp+OBS搭建流媒体推流服务