Decoupling Applications - SNS/SNS + SQS Fan-Out Pattern Flashcards
What is Amazon SNS (Simple Notification System)?
A fully managed publish-subscribe (Pub/Sub) messaging service that allows applications to send one message to many subscribers.
What is the Pub/Sub pattern?
A messaging pattern where:
Producers send messages to a topic (SNS topic).
Subscribers listen to the topic and receive messages.
What are the benefits of using SNS over direct integrations?
Decoupling: The producer only sends messages to the SNS topic without worrying about individual subscribers.
Scalability: Supports up to 12,000,000+ subscriptions per topic.
Flexibility: New subscribers can be added without modifying the producer.
What types of subscribers can SNS support?
Email
SMS and mobile notifications
HTTP/HTTPS endpoints
AWS Services:
SQS (queues)
Lambda (functions)
Kinesis Data Firehose (streaming to Redshift/S3)
Which AWS services can send notifications to SNS?
CloudWatch Alarms
Auto Scaling Groups
S3 events
CloudFormation state changes
RDS events
How does SNS handle security?
Encryption:
In-flight encryption by default.
At-rest encryption with KMS keys.
Client-side encryption (if implemented by the client).
Access Control:
Managed through IAM policies.
SNS access policies for cross-account access or service-specific permissions.
What are the steps to use SNS?
Create a Topic: A logical access point for messages.
Create Subscriptions: Define who will receive messages.
Publish Messages: Send messages to the topic using the SNS SDK or console.
How can you control access to SNS topics?
Using SNS Access Policies, similar to S3 bucket policies, to allow:
Cross-account access.
Service integrations like S3 writing to SNS.
What is the SNS + SQS Fan-Out Pattern?
A messaging architecture where:
Messages are sent to an SNS topic.
Multiple SQS queues are subscribed to the topic.
All subscribers receive a copy of each message.
Why use the Fan-Out Pattern?
Decoupling: The producer doesn’t directly interact with multiple queues.
Reliability: Ensures no message loss due to SQS persistence and retries.
Scalability: Easily add new queues as subscribers without modifying the producer.
How does SNS handle cross-region delivery?
SNS topics can send messages to SQS queues in different AWS regions if security policies allow it.
What is Message Filtering in SNS?
A feature to filter messages sent to specific SNS subscriptions based on JSON policies.
What are the benefits of Message Filtering?
Selective Delivery: Only relevant messages are sent to specific subscribers.
Reduced Processing Overhead: Avoids unnecessary processing for unrelated messages.