此异常表示消息体大小超出了 AWS SQS 的限制。解决方法是修改消息的大小或者使用 S3 存储消息体并在消息中包含 S3 存储对象的标识符。以下是一个修改消息大小的示例:
import json
import boto3
# 创建 SQS 客户端
sqs = boto3.client('sqs')
# 消息正文超过了 256 KB 的限制
large_msg_body = {
'key1': 'value1',
'key2': 'value2',
...
}
# 将消息正文转换为字符串
large_msg_body_str = json.dumps(large_msg_body)
# 将消息正文分割成小块,每块不超过 SQS 的最大值
max_chunk_size = 256 * 1024 # 256 KB
chunks = [large_msg_body_str[i:i+max_chunk_size] for i in range(0, len(large_msg_body_str), max_chunk_size)]
# 发送多个消息(一次发送多个消息是效率更高的)
queue_url = 'https://sqs.us-east-1.amazonaws.com/123456789012/myqueue'
for i, chunk in enumerate(chunks):
msg = {
'MessageBody': chunk,
'MessageGroupId': 'large_msg_group',
'MessageDeduplicationId': f'large_msg_{i}'
}
response = sqs.send_message(QueueUrl=queue_url, **msg)
print(response)
在本示例中,“large_msg_body” 是一个字典,它的字符串表示会超过 256 KB。我们按照固定大小将其分割成较小的块,并在循环中一次性发送多个块,以达到发送整条消息的效果。如果需要在消息体中包含文件或图片等大型二进制数据,则推荐使用 S3 存储来避免消息体大小限制问题。