InvalidParameterValue
cloud
config_error
ai_generated
true
InvalidParameterValue: The redrive policy for queue 'my-queue' is invalid. Reason: The dead-letter queue ARN is not valid.
ID: cloud/aws-sqs-redrive-policy-invalid
88%Fix Rate
84%Confidence
1Evidence
2024-12-01First Seen
Version Compatibility
| Version | Status | Introduced | Deprecated | Notes |
|---|---|---|---|---|
| AWS SDK for Python (boto3): 1.34.0 | active | — | — | — |
| SQS: 2012-11-05 | active | — | — | — |
| Terraform AWS Provider: 5.70.0 | active | — | — | — |
Root Cause
The dead-letter queue ARN specified in the redrive policy does not exist, is in a different region, or the source queue does not have permission to send messages to it.
generic中文
重驱策略中指定的死信队列 ARN 不存在、位于不同区域,或者源队列没有向其发送消息的权限。
Official Documentation
https://docs.aws.amazon.com/AWSSimpleQueueService/latest/SQSDeveloperGuide/sqs-dead-letter-queues.htmlWorkarounds
-
95% success Verify the dead-letter queue ARN using AWS CLI: aws sqs get-queue-attributes --queue-url <DLQ_URL> --attribute-names QueueArn. Then update the redrive policy with the correct ARN.
Verify the dead-letter queue ARN using AWS CLI: aws sqs get-queue-attributes --queue-url <DLQ_URL> --attribute-names QueueArn. Then update the redrive policy with the correct ARN.
-
90% success Attach a resource-based policy to the dead-letter queue allowing the source queue to send messages: aws sqs set-queue-attributes --queue-url <DLQ_URL> --attributes Policy='{"Version":"2012-10-17","Statement":[{"Effect":"Allow","Principal":"*","Action":"sqs:SendMessage","Resource":"<DLQ_ARN>","Condition":{"ArnEquals":{"aws:SourceArn":"<SOURCE_ARN>"}}}]}'
Attach a resource-based policy to the dead-letter queue allowing the source queue to send messages: aws sqs set-queue-attributes --queue-url <DLQ_URL> --attributes Policy='{"Version":"2012-10-17","Statement":[{"Effect":"Allow","Principal":"*","Action":"sqs:SendMessage","Resource":"<DLQ_ARN>","Condition":{"ArnEquals":{"aws:SourceArn":"<SOURCE_ARN>"}}}]}' -
85% success Ensure both queues are in the same AWS region; if not, create a new dead-letter queue in the same region as the source queue.
Ensure both queues are in the same AWS region; if not, create a new dead-letter queue in the same region as the source queue.
中文步骤
使用 AWS CLI 验证死信队列 ARN:aws sqs get-queue-attributes --queue-url <DLQ_URL> --attribute-names QueueArn。然后使用正确的 ARN 更新重驱策略。
向死信队列附加基于资源的策略,允许源队列发送消息:aws sqs set-queue-attributes --queue-url <DLQ_URL> --attributes Policy='{"Version":"2012-10-17","Statement":[{"Effect":"Allow","Principal":"*","Action":"sqs:SendMessage","Resource":"<DLQ_ARN>","Condition":{"ArnEquals":{"aws:SourceArn":"<SOURCE_ARN>"}}}]}'确保两个队列位于同一 AWS 区域;如果不在,则在源队列所在区域创建新的死信队列。
Dead Ends
Common approaches that don't work:
-
80% fail
Recreating queues does not fix the ARN mismatch or permission issue; the new queues have different ARNs unless explicitly specified.
-
90% fail
This only delays the problem; messages still get stuck in the source queue if processing fails repeatedly, and the redrive policy remains invalid.
-
95% fail
The redrive policy requires an ARN, not a URL; using a URL causes the same invalid parameter error.