将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

相关文章

Java中流式并行操作parallelStream的原理和使用方法

《Java中流式并行操作parallelStream的原理和使用方法》本文详细介绍了Java中的并行流(parallelStream)的原理、正确使用方法以及在实际业务中的应用案例,并指出在使用并行流... 目录Java中流式并行操作parallelStream0. 问题的产生1. 什么是parallelS

C++中unordered_set哈希集合的实现

《C++中unordered_set哈希集合的实现》std::unordered_set是C++标准库中的无序关联容器,基于哈希表实现,具有元素唯一性和无序性特点,本文就来详细的介绍一下unorder... 目录一、概述二、头文件与命名空间三、常用方法与示例1. 构造与析构2. 迭代器与遍历3. 容量相关4

Linux join命令的使用及说明

《Linuxjoin命令的使用及说明》`join`命令用于在Linux中按字段将两个文件进行连接,类似于SQL的JOIN,它需要两个文件按用于匹配的字段排序,并且第一个文件的换行符必须是LF,`jo... 目录一. 基本语法二. 数据准备三. 指定文件的连接key四.-a输出指定文件的所有行五.-o指定输出

Linux jq命令的使用解读

《Linuxjq命令的使用解读》jq是一个强大的命令行工具,用于处理JSON数据,它可以用来查看、过滤、修改、格式化JSON数据,通过使用各种选项和过滤器,可以实现复杂的JSON处理任务... 目录一. 简介二. 选项2.1.2.2-c2.3-r2.4-R三. 字段提取3.1 普通字段3.2 数组字段四.

C++中悬垂引用(Dangling Reference) 的实现

《C++中悬垂引用(DanglingReference)的实现》C++中的悬垂引用指引用绑定的对象被销毁后引用仍存在的情况,会导致访问无效内存,下面就来详细的介绍一下产生的原因以及如何避免,感兴趣... 目录悬垂引用的产生原因1. 引用绑定到局部变量,变量超出作用域后销毁2. 引用绑定到动态分配的对象,对象

Linux kill正在执行的后台任务 kill进程组使用详解

《Linuxkill正在执行的后台任务kill进程组使用详解》文章介绍了两个脚本的功能和区别,以及执行这些脚本时遇到的进程管理问题,通过查看进程树、使用`kill`命令和`lsof`命令,分析了子... 目录零. 用到的命令一. 待执行的脚本二. 执行含子进程的脚本,并kill2.1 进程查看2.2 遇到的

SpringBoot基于注解实现数据库字段回填的完整方案

《SpringBoot基于注解实现数据库字段回填的完整方案》这篇文章主要为大家详细介绍了SpringBoot如何基于注解实现数据库字段回填的相关方法,文中的示例代码讲解详细,感兴趣的小伙伴可以了解... 目录数据库表pom.XMLRelationFieldRelationFieldMapping基础的一些代

详解SpringBoot+Ehcache使用示例

《详解SpringBoot+Ehcache使用示例》本文介绍了SpringBoot中配置Ehcache、自定义get/set方式,并实际使用缓存的过程,文中通过示例代码介绍的非常详细,对大家的学习或者... 目录摘要概念内存与磁盘持久化存储:配置灵活性:编码示例引入依赖:配置ehcache.XML文件:配置

Java 虚拟线程的创建与使用深度解析

《Java虚拟线程的创建与使用深度解析》虚拟线程是Java19中以预览特性形式引入,Java21起正式发布的轻量级线程,本文给大家介绍Java虚拟线程的创建与使用,感兴趣的朋友一起看看吧... 目录一、虚拟线程简介1.1 什么是虚拟线程?1.2 为什么需要虚拟线程?二、虚拟线程与平台线程对比代码对比示例:三

k8s按需创建PV和使用PVC详解

《k8s按需创建PV和使用PVC详解》Kubernetes中,PV和PVC用于管理持久存储,StorageClass实现动态PV分配,PVC声明存储需求并绑定PV,通过kubectl验证状态,注意回收... 目录1.按需创建 PV(使用 StorageClass)创建 StorageClass2.创建 PV