-
Notifications
You must be signed in to change notification settings - Fork 16
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Amazon.SQS.AmazonSQSException: Submitted policy is over max allowed size #1021
Comments
Hi there, Thanks for the report 🙂. Are you able to please give us a little more information on your use case? It sounds like you might be using queue subscription filters, in which case there is a hard limit of 200 per account - are you close to this limit? I can't think of any reason this would cause transient failures, outside of deleting/recreating policies/queues regularly. Are you also able to maybe get a hold of a cleansed subscription policy so we can see what's taking up the space? Thanks! |
Hi, We are not using any subscription filters, so that shouldn't be the issue. We created a console and spammed the queues / notifications creation, even tried doing it when there were pending messages, but were unable to reproduce the issue locally, even though it still happens regularly on production. The policy generated is: {
"Version" : "2012-10-17",
"Statement" : [
{
"Sid" : "sID",
"Effect" : "Allow",
"Principal" : {
"AWS" : "*"
},
"Action" : "sqs:SendMessage",
"Resource" : "arn:aws:sqs:eu-west-1:accountID:queueName",
"Condition" : {
"ArnLike" : {
"aws:SourceArn" : "arn:aws:sns:eu-west-1:accountID:*"
}
}
}
]
} It doesn't look like it fits the exception, but maybe you same some idea what could be the issue here. This is how we register the queues and notifications justSaying
.WithSqsTopicSubscriber()
.IntoQueue("myQueue")
.ConfigureSubscriptionWith(c =>
{
c.RetryCountBeforeSendingToErrorQueue = 1;
c.VisibilityTimeoutSeconds = 300;
})
// messages to listen on topics for
.WithMessageHandler<NotifySubscriber>(handlerResolver)
.WithMessageHandler<ClientAddressCreated>(handlerResolver)
.WithMessageHandler<ClientAddressChanged>(handlerResolver)
.WithMessageHandler<ClientAddressDeleted>(handlerResolver)
.WithMessageHandler<ClientContactDetailCreated>(handlerResolver)
.WithMessageHandler<ClientContactDetailChanged>(handlerResolver)
.WithMessageHandler<ClientContactDetailDeleted>(handlerResolver)
.WithMessageHandler<ClientChanged>(handlerResolver)
.WithMessageHandler<ClientCreated>(handlerResolver)
.WithMessageHandler<DependantCreated>(handlerResolver)
.WithMessageHandler<DependantChanged>(handlerResolver)
.WithMessageHandler<DependantDeleted>(handlerResolver)
.WithMessageHandler<AssetCreated>(handlerResolver)
.WithMessageHandler<AssetChanged>(handlerResolver)
.WithMessageHandler<AssetDeleted>(handlerResolver)
.WithMessageHandler<AssetValuationCreated>(handlerResolver)
.WithMessageHandler<AssetValuationDeleted>(handlerResolver)
.WithMessageHandler<IncomeCreated>(handlerResolver)
.WithMessageHandler<IncomeChanged>(handlerResolver)
.WithMessageHandler<IncomeDeleted>(handlerResolver)
.WithMessageHandler<ExpenditureCreated>(handlerResolver)
.WithMessageHandler<ExpenditureChanged>(handlerResolver)
.WithMessageHandler<ExpenditureDeleted>(handlerResolver)
.WithMessageHandler<EmploymentCreated>(handlerResolver)
.WithMessageHandler<EmploymentChanged>(handlerResolver)
.WithMessageHandler<EmploymentDeleted>(handlerResolver)
.WithMessageHandler<IdentityCreated>(handlerResolver)
.WithMessageHandler<ClientRelationshipCreated>(handlerResolver)
.WithMessageHandler<ClientRelationshipChanged>(handlerResolver)
.WithMessageHandler<ClientRelationshipDeleted>(handlerResolver)
.WithMessageHandler<PlanCreated>(handlerResolver)
.WithMessageHandler<PlanChanged>(handlerResolver)
.WithMessageHandler<PlanDeleted>(handlerResolver)
.WithMessageHandler<PlanValuationCreated>(handlerResolver)
.WithMessageHandler<PlanValuationDeleted>(handlerResolver)
.WithSqsPointToPointSubscriber()
.IntoQueue("myQueue")
// messages to publish to local queue
.WithMessageHandler<ChangeOccurred>(handlerResolver)
.WithSqsMessagePublisher<ChangeOccurred>(config => config.QueueName = "myQueue")
.WithSqsMessagePublisher<NotifySubscriber>(config => config.QueueName = "myQueue")
// messages to publish to scheduler queue
.WithSqsMessagePublisher<ScheduleTimeout>(config => config.QueueName = "myQueue-scheduler")
.WithSqsMessagePublisher<UnscheduleTimeout>(config => config.QueueName = "myQueue-scheduler"); Thanks for your time. |
Btw, this two issues seem related. Potential regressions from AWS SDK. |
Describe the bug
On applications with around 20 SQS subscriptions, the following error occurs randomly when deploying:
Amazon.SQS.AmazonSQSException: Submitted policy is over max allowed size
The deployment works after a few retries.
The policy itself is the one generated in https://github.com/justeat/JustSaying/blob/v6.0.5/JustSaying/AwsTools/MessageHandling/SqsPolicy.cs and there is usually no issues with it.
What we found is that it's submitted every time a new SQS subscription is created and that may be the root cause of the issue on applications with a large amount of subscriptions.
Would it be better to check if the subscription and the policy already exist before creating them, or do you think that is not an issue and the cause is something else?
Steps To reproduce
As this only happens when the queues and subscriptions are already created (and may have messages) so its hard to reproduce.
Expected behaviour
Queues and subscriptions are created with no errors.
Actual behaviour
While queues and subscriptions are created, the following error occurs:
System information:
Additional context
The text was updated successfully, but these errors were encountered: