Ditching Subfolders: How to Directly Output AWS Media Convert Jobs to S3
Problem: You're using AWS Media Convert to transcode your videos and need them directly in your S3 bucket, not buried in subfolders. The default behavior is to create folders based on the job ID, making it inconvenient to access and manage your files.
Solution: This article shows you how to configure AWS Media Convert to output your transcoded videos directly to your S3 bucket, eliminating the need for subfolders.
Scenario:
Let's say you have a video file named "my_video.mp4" in your S3 bucket "my-bucket". You want to use AWS Media Convert to transcode it into multiple formats, including MP4 and WebM, and store the output files directly in the same bucket.
Original Code (with subfolders):
{
"Inputs": {
"FileInput": "s3://my-bucket/my_video.mp4"
},
"Outputs": [
{
"ContainerSettings": {
"Container": "MP4"
},
"VideoDescription": {
"Width": 640,
"Height": 360
},
"AudioDescription": {
"Codec": "AAC",
"CodecSettings": {
"Bitrate": 96000
}
},
"OutputGroups": [
{
"Name": "My Output Group",
"Output": {
"NameModifier": "_1080p",
"S3Output": {
"Bucket": "my-bucket"
}
}
},
{
"Name": "My WebM Output Group",
"Output": {
"NameModifier": "_720p",
"S3Output": {
"Bucket": "my-bucket"
}
}
}
]
}
]
}
This code would create subfolders within "my-bucket" like "my-bucket/jobId1/my_video_1080p.mp4" and "my-bucket/jobId1/my_video_720p.webm".
The Fix: Direct Output to S3
To avoid these subfolders, you need to modify the "S3Output" setting by adding the "Key" property:
{
"Inputs": {
"FileInput": "s3://my-bucket/my_video.mp4"
},
"Outputs": [
{
"ContainerSettings": {
"Container": "MP4"
},
"VideoDescription": {
"Width": 640,
"Height": 360
},
"AudioDescription": {
"Codec": "AAC",
"CodecSettings": {
"Bitrate": 96000
}
},
"OutputGroups": [
{
"Name": "My Output Group",
"Output": {
"NameModifier": "_1080p",
"S3Output": {
"Bucket": "my-bucket",
"Key": "${filename}_${namemodifier}.${extension}"
}
}
},
{
"Name": "My WebM Output Group",
"Output": {
"NameModifier": "_720p",
"S3Output": {
"Bucket": "my-bucket",
"Key": "${filename}_${namemodifier}.${extension}"
}
}
}
]
}
]
}
Explanation:
- ${filename}: This placeholder represents the original filename "my_video".
- ${namemodifier}: This placeholder takes the value from "NameModifier" in the "Output" settings.
- ${extension}: This placeholder represents the output file extension (e.g., ".mp4", ".webm").
Results:
With these changes, the transcoded videos will be directly saved in your "my-bucket" as "my_video_1080p.mp4" and "my_video_720p.webm", without any subfolders.
Benefits:
- Simplified File Management: No need to navigate through subfolders, making file access and organization more efficient.
- Easier Automation: Scripts and workflows can be easily designed to directly access and process files in the bucket.
- Improved Scalability: Direct output eliminates the potential bottleneck of managing and navigating through multiple subfolders as your number of transcoded videos grows.
Remember:
- You can use different formatting for the "Key" property to customize your file names and organization within the S3 bucket.
- You can use other placeholders available in AWS Media Convert, such as
${jobid}
for greater flexibility.
Resources:
By mastering this simple tweak, you can streamline your video workflow and manage your transcoded assets more effectively within your S3 bucket.