在 AWS Lambda 函数中流式传输音频时,请确保启用异步编程模式以避免阻塞并允许函数在响应时返回数据。
以下是一个 Python 函数示例,它从 S3 存储桶中读取音频文件并将其通过流式传输返回给调用者:
import boto3
def lambda_handler(event, context):
s3_client = boto3.client('s3')
bucket_name = 'my-bucket'
object_key = 'audio.mp3'
#创建用于流式传输的response对象
response = {
'statusCode': 200,
'isBase64Encoded': False,
'headers': {
'Content-Type': 'audio/mpeg'
},
'body': ''
}
#将response对象返回给调用者
yield response
#迭代通过流式传输返回的音频数据
for chunk in s3_client.get_object(Bucket=bucket_name, Key=object_key)['Body'].iter_chunks():
yield chunk
请注意,此示例使用 Python 的 yield 来异步生成从 S3 存储桶读取的数据块。在有新数据块就可以返回给调用者时,函数将调用 yield 来生成数据块。如果数据块还没有可用,则函数将被挂起。这使得函数可以异步地为调用者传输音频数据,而无需阻塞并等待整个音频文件读取完毕。
要测试此示例,请将代码复制并粘贴到 AWS Lambda 控制台中,然后修改 Bucket 名称和 Object Key,以匹配您 S3 存储桶和要流式传输的音频文件的名称。最后,请确保启用异步编程模式,并测试函数以确保正常工作。