将rtsp视频流发送到AWS Kinesis Video Streams的方案——使用Gstreamer(C++) Command Line

本文主要是介绍将rtsp视频流发送到AWS Kinesis Video Streams的方案——使用Gstreamer(C++) Command Line,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

大纲

  • 1 创建Kinesis Video Streams
    • 1.1 创建视频流
    • 1.2 记录Creation Time
  • 2 创建策略
    • 2.1 赋予权限
    • 2.2 限制资源
    • 2.3 Json格式描述(或上面手工设置)
    • 2.4 注意事项
  • 3 创建IAM用户
    • 3.1 生成密钥对
    • 3.2 附加策略
    • 3.3 记录访问密钥对
  • 4 编译C++ 创建者库
  • 5 发送
  • 6 检查
  • 参考文献

我们的实验都是在us-east-1上进行的。如果想在其他区域做实验,可以将下面us-east-1都改成对应的区域。

1 创建Kinesis Video Streams

登录到https://us-east-1.console.aws.amazon.com/kinesisvideo/home?region=us-east-1#/streams

1.1 创建视频流

创建名称为RtspVideoStream的视频流
在这里插入图片描述

1.2 记录Creation Time

上步创建完后,我们可以从ARN中获取Creation Time。这个字段之后要在配置策略时使用到。
在这里插入图片描述

2 创建策略

登录到https://us-east-1.console.aws.amazon.com/iamv2/home#/policies
创建名称为RtspVideoStreamPolicy的策略

2.1 赋予权限

在这里插入图片描述

2.2 限制资源

在这里插入图片描述
在Stream name处填写上一步创建的流的名称RtspVideoStream,Creation time处填写之前从ARN中获取的1659609702642。Account会自动填写根账号的ID。
在这里插入图片描述

2.3 Json格式描述(或上面手工设置)

注意将ACCOUNTID替换成自己账号的ID

{
“Version”: “2012-10-17”,
“Statement”: [
{
“Sid”: “VisualEditor0”,
“Effect”: “Allow”,
“Action”: [
“kinesisvideo:PutMedia”,
“kinesisvideo:GetDataEndpoint”,
“kinesisvideo:DescribeStream”
],
“Resource”: “arn:aws:kinesisvideo:us-east-1:AccountID:stream/RtspVideoStream/1659609702642”
}
]
}

2.4 注意事项

如果不希望做到精确控制权限,或者希望快速使用,可以将此策略配置为:所有资源的所有权限。

3 创建IAM用户

登录https://us-east-1.console.aws.amazon.com/iamv2/home#/users
创建名为KinesisVideoStreamsUser的用户。

3.1 生成密钥对

需要勾选Access key - Programmatic access。
在这里插入图片描述

3.2 附加策略

附加上一步创建的策略——RtspVideoStreamPolicy。
在这里插入图片描述

3.3 记录访问密钥对

下载保存(或复制)Access key ID和Secret access key密钥对。
在这里插入图片描述

4 编译C++ 创建者库

我的测试环境是Ubuntu,在console中输入以下指令编译。其中cmake时间有点长,需要耐心等待下。

git clone https://github.com/awslabs/amazon-kinesis-video-streams-producer-sdk-cpp.git
mkdir -p amazon-kinesis-video-streams-producer-sdk-cpp/build
cd amazon-kinesis-video-streams-producer-sdk-cpp/build
sudo apt-get install libssl-dev libcurl4-openssl-dev liblog4cplus-dev libgstreamer1.0-dev libgstreamer-plugins-base1.0-dev gstreamer1.0-plugins-base-apps gstreamer1.0-plugins-bad gstreamer1.0-plugins-good gstreamer1.0-plugins-ugly gstreamer1.0-tools
sudo apt install cmake
cmake -DBUILD_GSTREAMER_PLUGIN=TRUE ..
make
cd ..
export GST_PLUGIN_PATH=`pwd`/build
export LD_LIBRARY_PATH=`pwd`/open-source/local/lib

5 发送

执行下面指令(注意替换YourAccessKeyYourSecretKey为KinesisVideoStreamsUser对应的值):

gst-launch-1.0 -v rtspsrc location=rtsp://wowzaec2demo.streamlock.net/vod/mp4:BigBuckBunny_115k.mp4 short-header=TRUE ! rtph264depay ! h264parse ! kvssink stream-name=RtspVideoStream storage-size=128 access-key=“YourAccessKey” secret-key=“YourSecretKey” aws-region=“us-east-1”

rtsp://wowzaec2demo.streamlock.net/vod/mp4:BigBuckBunny_115k.mp4是网上找的公开的rtsp流。至于流有没有效,可以下载VLC播放器测试。
在这里插入图片描述
在这里插入图片描述

6 检查

再登录到Kinesis Video Streams。可以在线查看推送过来的视频。
在这里插入图片描述
如果这个rtsp失效了,可以在本地搭建一个rtsp服务器,然后使用ffmpeg推送视频流。具体的做法可以见《在Windows操作系统上使用rtsp simple server和ffmpeg推送录屏视频流》。

参考文献

  1. https://docs.aws.amazon.com/zh_cn/kinesisvideostreams/latest/dg/producer-sdk-cpp.html
  2. https://github.com/awslabs/amazon-kinesis-video-streams-producer-sdk-cpp/blob/master/docs/linux.md

这篇关于将rtsp视频流发送到AWS Kinesis Video Streams的方案——使用Gstreamer(C++) Command Line的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/456564

相关文章

使用Python实现IP地址和端口状态检测与监控

《使用Python实现IP地址和端口状态检测与监控》在网络运维和服务器管理中,IP地址和端口的可用性监控是保障业务连续性的基础需求,本文将带你用Python从零打造一个高可用IP监控系统,感兴趣的小伙... 目录概述:为什么需要IP监控系统使用步骤说明1. 环境准备2. 系统部署3. 核心功能配置系统效果展

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

redis中使用lua脚本的原理与基本使用详解

《redis中使用lua脚本的原理与基本使用详解》在Redis中使用Lua脚本可以实现原子性操作、减少网络开销以及提高执行效率,下面小编就来和大家详细介绍一下在redis中使用lua脚本的原理... 目录Redis 执行 Lua 脚本的原理基本使用方法使用EVAL命令执行 Lua 脚本使用EVALSHA命令

C#如何调用C++库

《C#如何调用C++库》:本文主要介绍C#如何调用C++库方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录方法一:使用P/Invoke1. 导出C++函数2. 定义P/Invoke签名3. 调用C++函数方法二:使用C++/CLI作为桥接1. 创建C++/CL

Java 中的 @SneakyThrows 注解使用方法(简化异常处理的利与弊)

《Java中的@SneakyThrows注解使用方法(简化异常处理的利与弊)》为了简化异常处理,Lombok提供了一个强大的注解@SneakyThrows,本文将详细介绍@SneakyThro... 目录1. @SneakyThrows 简介 1.1 什么是 Lombok?2. @SneakyThrows

使用Python和Pyecharts创建交互式地图

《使用Python和Pyecharts创建交互式地图》在数据可视化领域,创建交互式地图是一种强大的方式,可以使受众能够以引人入胜且信息丰富的方式探索地理数据,下面我们看看如何使用Python和Pyec... 目录简介Pyecharts 简介创建上海地图代码说明运行结果总结简介在数据可视化领域,创建交互式地

Java Stream流使用案例深入详解

《JavaStream流使用案例深入详解》:本文主要介绍JavaStream流使用案例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录前言1. Lambda1.1 语法1.2 没参数只有一条语句或者多条语句1.3 一个参数只有一条语句或者多

Java Spring 中 @PostConstruct 注解使用原理及常见场景

《JavaSpring中@PostConstruct注解使用原理及常见场景》在JavaSpring中,@PostConstruct注解是一个非常实用的功能,它允许开发者在Spring容器完全初... 目录一、@PostConstruct 注解概述二、@PostConstruct 注解的基本使用2.1 基本代

C#使用StackExchange.Redis实现分布式锁的两种方式介绍

《C#使用StackExchange.Redis实现分布式锁的两种方式介绍》分布式锁在集群的架构中发挥着重要的作用,:本文主要介绍C#使用StackExchange.Redis实现分布式锁的... 目录自定义分布式锁获取锁释放锁自动续期StackExchange.Redis分布式锁获取锁释放锁自动续期分布式

springboot使用Scheduling实现动态增删启停定时任务教程

《springboot使用Scheduling实现动态增删启停定时任务教程》:本文主要介绍springboot使用Scheduling实现动态增删启停定时任务教程,具有很好的参考价值,希望对大家有... 目录1、配置定时任务需要的线程池2、创建ScheduledFuture的包装类3、注册定时任务,增加、删