- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
看完这篇article我觉得 AWS 媒体转换作业模板不能重复用于生成任意视频大小的缩略图。本文假设我们知道预先上传的视频的大小/持续时间,因此我们需要的缩略图数量。
我正在寻找的是根据视频大小生成随机数量的缩略图(例如,大视频的大量缩略图和小视频的少量缩略图)。我使用 lambda 触发器和 ffmpeg lambda 层接近了这个解决方案,但是对于大于 150MB 的视频,lambda 函数超时(最多 15 分钟)(因为从 s3 存储桶中读取视频需要时间)。
我有哪些选择来处理大量视频、生成可变数量的缩略图、合并这些缩略图以生成 Sprite ?
我尝试使用 ffmpeg/ffprob 的 lambda 触发器来生成 Sprite ,但这有超时问题。现在我已经设置了一个云监视事件规则来触发 mediaconvert 作业状态更改的 lambda 函数(已完成)
并合并拇指以生成 Sprite ,这看起来要轻得多,但我需要任意数量的拇指。
最佳答案
您可以从使用 ffprobe 切换到 MediaInfo [1]。这可以获得输入文件的持续时间和文件大小。从那里您可以使用文章中的计算并使用 MediaConvert 创建您的 Sprite 图像。作业完成后,您可以使用 COMPLETE CloudWatch Event 触发可以创建 Sprite list 的后处理工作流。默认情况下,COMPLETE 详细信息部分将包括从您的 MediaConvert 输出 [2] 到最后一个 JPEG 帧捕获的输出路径。
作为预处理步骤,您可以收集文件的持续时间以及大小。如果您只需要文件的大小,那么您可以使用 S3 SDK 获取文件的内容长度(调用 HEAD 到对象)并从那里计算。
s3 = boto3.client('s3')
response = s3.head_object(Bucket='bucket', Key='keyname')
size = response['ContentLength']
print(size)
您还可以在作业模板中使用参数覆盖。例如,您可以创建一个引用模板的作业,但您可以通过调用 CreateJob API 来指定覆盖这些设置的设置。
System-Avc_16x9_720p_29_97fps_3500kbps
System-Avc_16x9_360p_29_97fps_1200kbps
System-Avc_16x9_270p_14_99fps_400kbps
JSON Payload 更改了输出 2 (System-Avc_16x9_360p_29_97fps_1200kbps) 和输出 3 (System-Avc_16x9_270p_14_99fps_400kbps) 的音频选择器源名称
{
"Queue": "arn:aws:mediaconvert:us-west-2:111122223333:queues/Default",
"UserMetadata": {},
"Role": "arn:aws:iam::111122223333:role/EMFRoleSPNames",
"Settings": {
"OutputGroups": [
{
"Name": "Apple HLS",
"Outputs": [
{
"NameModifier": "_1",
"Preset": "System-Avc_16x9_720p_29_97fps_3500kbps"
},
{
"NameModifier": "_2",
"Preset": "System-Avc_16x9_360p_29_97fps_1200kbps",
"AudioDescriptions": [
{
"AudioSourceName": "Audio Selector 2"
}
]
},
{
"NameModifier": "_3",
"Preset": "System-Avc_16x9_270p_14_99fps_400kbps",
"AudioDescriptions": [
{
"AudioSourceName": "Audio Selector 2"
}
]
}
],
"OutputGroupSettings": {
"Type": "HLS_GROUP_SETTINGS",
"HlsGroupSettings": {
"ManifestDurationFormat": "INTEGER",
"SegmentLength": 10,
"TimedMetadataId3Period": 10,
"CaptionLanguageSetting": "OMIT",
"Destination": "s3://myawsbucket/out/master",
"TimedMetadataId3Frame": "PRIV",
"CodecSpecification": "RFC_4281",
"OutputSelection": "MANIFESTS_AND_SEGMENTS",
"ProgramDateTimePeriod": 600,
"MinSegmentLength": 0,
"DirectoryStructure": "SINGLE_DIRECTORY",
"ProgramDateTime": "EXCLUDE",
"SegmentControl": "SEGMENTED_FILES",
"ManifestCompression": "NONE",
"ClientCache": "ENABLED",
"StreamInfResolution": "INCLUDE"
}
}
}
],
"Inputs": [
{
"AudioSelectors": {
"Audio Selector 1": {
"Offset": 0,
"DefaultSelection": "DEFAULT",
"ProgramSelection": 1,
"SelectorType": "TRACK",
"Tracks": [
1
]
},
"Audio Selector 2": {
"Offset": 0,
"DefaultSelection": "NOT_DEFAULT",
"ProgramSelection": 1,
"SelectorType": "TRACK",
"Tracks": [
2
]
}
},
"VideoSelector": {
"ColorSpace": "FOLLOW"
},
"FilterEnable": "AUTO",
"PsiControl": "USE_PSI",
"FilterStrength": 0,
"DeblockFilter": "DISABLED",
"DenoiseFilter": "DISABLED",
"TimecodeSource": "EMBEDDED",
"FileInput": "s3://myawsbucket/input/test.mp4"
}
],
"TimecodeConfig": {
"Source": "EMBEDDED"
}
}
}
== 资源 ==
关于ffmpeg - 使用 AWS MediaConvert 根据视频大小生成缩略图数量,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/65076791/
看完这篇article我觉得 AWS 媒体转换作业模板不能重复用于生成任意视频大小的缩略图。本文假设我们知道预先上传的视频的大小/持续时间,因此我们需要的缩略图数量。 我正在寻找的是根据视频大小生成随
我目前正在 AWS 中从我的 Lambda 函数创建一个 MediaConvert 作业,并使用它来转换我的媒体并创建缩略图。但是,尝试转换没有音频的媒体时失败。 Invalid audio trac
我正在使用从 NPM 安装的 Amazon AWS SDK 创建 typescript 应用程序。我可以使用 AWS.S3 对象进行调用,但无法使用 AWS.MediaConvert: var end
我正在使用以下 Python 和 json 媒体转换作业来运行 AWS MediaConvert 作业。 (我遵循的原始指南是 here )。 MediaConvert 作业创建的新文件的 ACL 应
我想实现完全相同的 CSS 行为:background-size: contain。 但我只能选择信箱或拉伸(stretch): 当我们同时提供宽度和高度作为约束时,我们如何保持纵横比? 最佳答案 有
我是 Terraform 的新手,已经开始为我的基础设施创建 .tf 文件,目前为止涉及 AWS S3 和 IAM 角色。到目前为止一切都很好。 但现在我需要通过 Terraform 创建一个 AWS
我正在使用 AWS“Elemental MediaConvert”服务获取上传视频的 HLS 格式。我们将其用作视频点播服务。一切正常。上传到“s3-input”存储桶中的视频将由 lambda 服务
我正在使用 AWS“Elemental MediaConvert”服务获取上传视频的 HLS 格式。我们将其用作视频点播服务。一切正常。上传到“s3-input”存储桶中的视频将由 lambda 服务
我想使用 aws mediaconvert 服务进行视频拼接。拥有 AWS 的付费帐户,可以访问 mediaConvert 服务。能够通过mediaConvert控制台创建视频拼接作业。现在我正在使用
我已经使用“AWS 上的视频点播”CloudFormation 模板几年了,几乎没有出现任何问题,但最近在将 4K 视频 (.mp4) 上传到管道(例如从 iPhone)时,我发现收到以下错误: Ba
我正在尝试使用 MediaConvert 对视频进行转码,但出现以下错误: Error message Demuxer: [ReadPacketData File read failed - end
我是一名优秀的程序员,十分优秀!