messageDeduplicationId
This parameter applies only to FIFO (first-in-first-out) topics.
This parameter applies only to FIFO (first-in-first-out) topics. The
MessageDeduplicationIdcan contain up to 128 alphanumeric characters(a-z, A-Z, 0-9)and punctuation(!"#$%&'()*+,-./:;<=>?@[\]^_{|}~)`.Every message must have a unique
MessageDeduplicationId, which is a token used for deduplication of sent messages within the 5 minute minimum deduplication interval.The scope of deduplication depends on the
FifoThroughputScopeattribute, when set toTopicthe message deduplication scope is across the entire topic, when set toMessageGroupthe message deduplication scope is within each individual message group.If a message with a particular
MessageDeduplicationIdis sent successfully, subsequent messages within the deduplication scope and interval, with the sameMessageDeduplicationId, are accepted successfully but aren't delivered.Every message must have a unique
MessageDeduplicationId.You may provide a
MessageDeduplicationIdexplicitly.If you aren't able to provide a
MessageDeduplicationIdand you enableContentBasedDeduplicationfor your topic, Amazon SNS uses a SHA-256 hash to generate theMessageDeduplicationIdusing the body of the message (but not the attributes of the message).If you don't provide a
MessageDeduplicationIdand the topic doesn't haveContentBasedDeduplicationset, the action fails with an error.If the topic has a
ContentBasedDeduplicationset, yourMessageDeduplicationIdoverrides the generated one.When
ContentBasedDeduplicationis in effect, messages with identical content sent within the deduplication scope and interval are treated as duplicates and only one copy of the message is delivered.If you send one message with
ContentBasedDeduplicationenabled, and then another message with aMessageDeduplicationIdthat is the same as the one generated for the firstMessageDeduplicationId, the two messages are treated as duplicates, within the deduplication scope and interval, and only one copy of the message is delivered.
The MessageDeduplicationId is available to the consumer of the message (this can be useful for troubleshooting delivery issues).
If a message is sent successfully but the acknowledgement is lost and the message is resent with the same MessageDeduplicationId after the deduplication interval, Amazon SNS can't detect duplicate messages.
Amazon SNS continues to keep track of the message deduplication ID even after the message is received and deleted.