πŸ“š AWS DVA-C02 Exam Study Guide

Comprehensive Summary Organized by AWS Services

Last Updated: March 27, 2026


πŸ“Š Exam Focus Areas

πŸ”₯ Heavy Focus (Multiple Questions)

  • Lambda - Serverless compute
  • API Gateway - RESTful API management
  • SNS - Notification service
  • SQS - Message queuing
  • KMS - Key management
  • CloudWatch - Monitoring & logging
  • IAM - Identity & access management

πŸ“ 1-2 Questions Each

  • CI/CD (CodeDeploy, CodePipeline, CodeBuild)
  • S3, DynamoDB, RDS
  • Secrets Manager, Systems Manager (SSM)
  • Elastic Beanstalk, CloudFormation
  • ECS/EKS, ElastiCache

⚠️ Variable Coverage

  • X-Ray, Step Functions, Kinesis, AppConfig
  • Note: Question distribution varies by exam set

πŸ” IAM & Security

IAM Roles & Policies

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚                  IAM Role Types                          β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                                          β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”      β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”       β”‚
β”‚  β”‚ Instance Profile β”‚      β”‚  Execution Role  β”‚       β”‚
β”‚  β”‚                  β”‚      β”‚                  β”‚       β”‚
β”‚  β”‚  EC2 β†’ IAM Role  β”‚      β”‚ Lambda/ECS Perms β”‚       β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜      β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜       β”‚
β”‚                                                          β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”      β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”       β”‚
β”‚  β”‚    Task Role     β”‚      β”‚  Service Role    β”‚       β”‚
β”‚  β”‚                  β”‚      β”‚                  β”‚       β”‚
β”‚  β”‚ ECS Task Perms   β”‚      β”‚ AWS Service Permsβ”‚       β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜      β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜       β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Best Practice: Assign separate IAM roles per task/function (Principle of Least Privilege)

AWS STS (Security Token Service)

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚              STS Token Types & Use Cases                  β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                                           β”‚
β”‚  GetSessionToken                                          β”‚
β”‚  β”œβ”€ Use: IAM user temp credentials                       β”‚
β”‚  β”œβ”€ Duration: 15 min - 36 hours (default 12 hrs)         β”‚
β”‚  └─ Scenario: MFA-protected API calls                    β”‚
β”‚                                                           β”‚
β”‚  GetFederationToken                                       β”‚
β”‚  β”œβ”€ Use: Grant temp access to federated users            β”‚
β”‚  └─ Scenario: App giving access to others                β”‚
β”‚                                                           β”‚
β”‚  AssumeRoleWithWebIdentity                                β”‚
β”‚  β”œβ”€ Use: Social login (Google, Facebook)                 β”‚
β”‚  └─ Scenario: Mobile app authentication                  β”‚
β”‚                                                           β”‚
β”‚  AssumeRoleWithSAML                                       β”‚
β”‚  β”œβ”€ Use: Corporate SSO/SAML IdP                          β”‚
β”‚  └─ Scenario: Enterprise federation                      β”‚
β”‚                                                           β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Cross-Account Access Pattern

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚         Cross-Account Resource Access Flow                  β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

  Account A (Dev)              Account B (Production)
  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”             β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
  β”‚              β”‚             β”‚                      β”‚
  β”‚  IAM User    β”‚             β”‚   IAM Role           β”‚
  β”‚  (Developer) β”‚             β”‚   (S3AccessRole)     β”‚
  β”‚              β”‚             β”‚                      β”‚
  β””β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”˜             β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
         β”‚                                β”‚
         β”‚  1. AssumeRole (STS)          β”‚
         β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€>β”‚
         β”‚                                β”‚
         β”‚  2. Temporary Credentials      β”‚
         β”‚<────────────────────────────────
         β”‚                                β”‚
         β”‚  3. Access S3 with Temp Creds β”‚
         β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€>β”‚
         β”‚                                β”‚
         β”‚  4. Resource Access Granted    β”‚
         β”‚<────────────────────────────────
         β”‚                                β”‚
         β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Configuration:

  1. Create IAM role in Account B with trust policy for Account A
  2. Attach S3 permissions to the role
  3. Grant Account A users permission to assume the role

πŸ—„οΈ DynamoDB

Table Structure & Keys

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚              DynamoDB Table Architecture                  β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                                           β”‚
β”‚  ┏━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┓  β”‚
β”‚  ┃  Table: OrdersTable                               ┃  β”‚
β”‚  ┣━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┫  β”‚
β”‚  ┃  Partition Key: UserID                            ┃  β”‚
β”‚  ┃  Sort Key: OrderDate                              ┃  β”‚
β”‚  ┗━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━━┛  β”‚
β”‚                                                           β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”      β”‚
β”‚  β”‚ Partition 1         β”‚   β”‚ Partition 2         β”‚      β”‚
β”‚  β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€   β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€      β”‚
β”‚  β”‚ UserID: user-123    β”‚   β”‚ UserID: user-456    β”‚      β”‚
β”‚  β”‚ Orders: [....]      β”‚   β”‚ Orders: [....]      β”‚      β”‚
β”‚  β”‚ Max: 10 GB          β”‚   β”‚ Max: 10 GB          β”‚      β”‚
β”‚  β”‚ 3000 RCU / 1000 WCU β”‚   β”‚ 3000 RCU / 1000 WCU β”‚      β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜   β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜      β”‚
β”‚                                                           β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Secondary Indexes Comparison

FeatureGSI (Global)LSI (Local)
Partition KeyCan be differentMust be same as table
Sort KeyCan be differentMust be different
ScopeSpans all partitionsLocal to partition
CreationAnytimeOnly at table creation
LimitNo limit5 per table
SizeNo limit10 GB per partition
ThroughputSeparate capacityShares with table
ConsistencyEventually consistentStrongly or eventually consistent

DynamoDB Streams

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚           DynamoDB Streams Architecture                   β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

  DynamoDB Table
  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
  β”‚  Item Modified β”‚
  β””β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”˜
           β”‚
           β–Ό
  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”      StreamViewType Options:
  β”‚ DynamoDB       β”‚      β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
  β”‚ Stream         β”‚      β”‚ KEYS_ONLY                   β”‚
  β”‚ (24 hrs)       β”‚      β”‚ NEW_IMAGE    (after modify) β”‚
  β””β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”˜      β”‚ OLD_IMAGE    (before modify)β”‚
           β”‚              β”‚ NEW_AND_OLD_IMAGES          β”‚
           β”‚              β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
           β–Ό
  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
  β”‚ Lambda         β”‚
  β”‚ Trigger        β”‚
  β”‚ (Process)      β”‚
  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Use Case: Capture item-level changes for audit, backup, or replication

Hot Partition Problem & Solutions

❌ BAD: Hot Partition
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚ Partition Key: OrderDate               β”‚
β”‚ Problem: All orders on same date       β”‚
β”‚          go to same partition          β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚  2024-03-27  β†’  Partition 1 [OVERLOAD]β”‚
β”‚  2024-03-27  β†’  Partition 1 [OVERLOAD]β”‚
β”‚  2024-03-27  β†’  Partition 1 [OVERLOAD]β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

βœ… GOOD: Distributed Load
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚ Partition Key: OrderDate + Random(1-10)β”‚
β”‚ Solution: Distributes writes evenly    β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚  2024-03-27#1  β†’  Partition 1          β”‚
β”‚  2024-03-27#5  β†’  Partition 5          β”‚
β”‚  2024-03-27#3  β†’  Partition 3          β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Solutions for Hot Partitions:

  • Add random suffix to partition key
  • Use high cardinality attributes (email, user_id)
  • Use composite attributes
  • Cache popular items

Query vs Scan

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚                  Query vs Scan                            β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                                           β”‚
β”‚  QUERY (Efficient βœ…)                                     β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”        β”‚
β”‚  β”‚ SELECT * FROM Orders                         β”‚        β”‚
β”‚  β”‚ WHERE UserID = "user-123"                    β”‚        β”‚
β”‚  β”‚ AND OrderDate > "2024-01-01"                 β”‚        β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜        β”‚
β”‚  β€’ Uses partition key (required)                         β”‚
β”‚  β€’ Optional sort key condition                           β”‚
β”‚  β€’ Fast, low RCU consumption                             β”‚
β”‚                                                           β”‚
β”‚  SCAN (Inefficient ❌)                                    β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”        β”‚
β”‚  β”‚ SELECT * FROM Orders                         β”‚        β”‚
β”‚  β”‚ // Reads entire table, then filters         β”‚        β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜        β”‚
β”‚  β€’ Reads all items, then filters                         β”‚
β”‚  β€’ Slow, high RCU consumption                            β”‚
β”‚  β€’ Use smaller page size to reduce impact                β”‚
β”‚  β€’ Consider parallel scans for large tables              β”‚
β”‚                                                           β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Batch Operations

OperationDescriptionLimit
BatchGetItemRead multiple items100 items, 16 MB max
BatchWriteItemWrite/Delete multiple items25 items
QueryGet items with same partition key1 MB per request
ScanRead entire table1 MB per page

Optimistic Locking Pattern

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚         Optimistic Locking Flow (Prevents Overwrites)     β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

  User A                    DynamoDB Table              User B
  β”Œβ”€β”€β”€β”€β”€β”€β”                  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”               β”Œβ”€β”€β”€β”€β”€β”€β”
  β”‚      β”‚                  β”‚ Item:    β”‚               β”‚      β”‚
  β”‚      β”‚  1. Read         β”‚ id=123   β”‚  1. Read      β”‚      β”‚
  β”‚      β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€>β”‚ version=5β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€>β”‚      β”‚
  β”‚      β”‚                  β”‚          β”‚               β”‚      β”‚
  β”‚      β”‚  2. Modify       β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜  2. Modify    β”‚      β”‚
  β”‚      β”‚     locally                       locally   β”‚      β”‚
  β”‚      β”‚                                              β”‚      β”‚
  β”‚      β”‚  3. Write (v=5)                             β”‚      β”‚
  β”‚      β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€>                           β”‚      β”‚
  β”‚      β”‚     βœ… Success!                              β”‚      β”‚
  β”‚      β”‚     version=6                                β”‚      β”‚
  β”‚      β”‚                                              β”‚      β”‚
  β”‚      β”‚                  4. Write (v=5) ❌           β”‚      β”‚
  β”‚      β”‚                  <───────────────────────────      β”‚
  β”‚      β”‚                     FAILS! Version mismatch β”‚      β”‚
  β”‚      β”‚                     (expected 5, found 6)   β”‚      β”‚
  β””β”€β”€β”€β”€β”€β”€β”˜                                              β””β”€β”€β”€β”€β”€β”€β”˜

Implementation: Use a version number attribute and conditional writes


πŸ”₯ AWS Lambda

Lambda Execution Model

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚              Lambda Invocation Types                      β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚  RequestResponse (Synchronous)                           β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚  Client β†’ Lambda β†’ [Processing] β†’ Response β†’ Client     β”‚
β”‚  β€’ Wait for result                                       β”‚
β”‚  β€’ Return value to caller                                β”‚
β”‚  β€’ Use: API calls, immediate response needed             β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚  Event (Asynchronous)                                    β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚  Client β†’ Lambda β†’ [202 Accepted] β†’ Client              β”‚
β”‚                    [Processing in background]            β”‚
β”‚  β€’ Don't wait for result                                 β”‚
β”‚  β€’ Lambda handles retries                                β”‚
β”‚  β€’ Use: Background jobs, parallel processing             β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚  DryRun (Validation)                                     β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚  Client β†’ Lambda β†’ [Validate only] β†’ Response           β”‚
β”‚  β€’ No execution                                          β”‚
β”‚  β€’ Check permissions & parameters                        β”‚
β”‚  β€’ Use: Testing without running                          β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Lambda Event Source Mapping

Event Source β†’ Lambda Polls β†’ Lambda Function Executes

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”     β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”     β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚  Kinesis    β”‚     β”‚   Lambda     β”‚     β”‚   Lambda     β”‚
β”‚  Stream     β”‚<────│   Service    │────>β”‚   Function   β”‚
β”‚  (Shards)   β”‚     β”‚   (Polls)    β”‚     β”‚              β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜     β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜     β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
     β”‚                                          
     β”‚              β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”           
     β”‚              β”‚  DynamoDB    β”‚           
     └──────────────│  Streams     β”‚           
                    β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜           
                           β”‚                   
                    β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”           
                    β”‚     SQS      β”‚           
                    β”‚    Queue     β”‚           
                    β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜           

Key Point: 1 Lambda execution per Kinesis/DynamoDB shard (concurrency = shard count)

Lambda Concurrency

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚         Lambda Concurrency Limits                         β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                                           β”‚
β”‚  Account Limit: 1,000 concurrent executions              β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”    β”‚
β”‚  β”‚ Reserved: 900 (max)                              β”‚    β”‚
β”‚  β”‚ β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                β”‚    β”‚
β”‚  β”‚ β”‚ Function A  β”‚  β”‚ Function B  β”‚                β”‚    β”‚
β”‚  β”‚ β”‚ Reserved:   β”‚  β”‚ Reserved:   β”‚                β”‚    β”‚
β”‚  β”‚ β”‚    450      β”‚  β”‚    450      β”‚                β”‚    β”‚
β”‚  β”‚ β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                β”‚    β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜    β”‚
β”‚  Unreserved: 100 (minimum, always available)             β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”    β”‚
β”‚  β”‚ Shared by all other functions                    β”‚    β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜    β”‚
β”‚                                                           β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Rule: Cannot reserve more than 900 (must leave 100 unreserved)

Lambda@Edge

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚           Lambda@Edge with CloudFront                     β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

                    Global Users
                         β”‚
                         β–Ό
         β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
         β”‚   CloudFront Edge Location    β”‚
         β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
         β”‚                               β”‚
         β”‚  1. Viewer Request            β”‚
         β”‚     ↓                         β”‚
         β”‚  [Lambda@Edge] ← Auth Check   β”‚
         β”‚     ↓                         β”‚
         β”‚  2. Origin Request            β”‚
         β”‚     ↓                         β”‚
         β”‚  [Lambda@Edge] ← Add Headers  β”‚
         β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
                         β”‚
                         β–Ό
                   Origin Server

Use Cases:

  • User authentication at edge
  • Request/response manipulation
  • A/B testing
  • Bot detection

🌐 API Gateway

Integration Types

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚            API Gateway Integration Types                  β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                                           β”‚
β”‚  HTTP_PROXY (Pass-through)                               β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”       β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”       β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”      β”‚
β”‚  β”‚ Client  │──────>β”‚   API   │──────>β”‚  HTTP    β”‚      β”‚
β”‚  β”‚         β”‚<──────│ Gateway β”‚<──────│ Endpoint β”‚      β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜       β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜       β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜      β”‚
β”‚  β€’ No transformation                                     β”‚
β”‚                                                           β”‚
β”‚  HTTP (Custom)                                           β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”       β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”       β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”      β”‚
β”‚  β”‚ Client  │──────>β”‚   API   │──────>β”‚  HTTP    β”‚      β”‚
β”‚  β”‚         β”‚<──────│ Gateway β”‚<──────│ Endpoint β”‚      β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜       β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜       β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜      β”‚
β”‚  β€’ With mapping templates                                β”‚
β”‚                                                           β”‚
β”‚  AWS_PROXY (Lambda Proxy) ⭐ Most Common                 β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”       β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”       β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”      β”‚
β”‚  β”‚ Client  │──────>β”‚   API   │──────>β”‚  Lambda  β”‚      β”‚
β”‚  β”‚         β”‚<──────│ Gateway β”‚<──────│ Function β”‚      β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜       β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜       β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜      β”‚
β”‚  β€’ Entire request passed to Lambda                       β”‚
β”‚  β€’ No mapping needed                                     β”‚
β”‚                                                           β”‚
β”‚  AWS (Custom)                                            β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”       β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”       β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”      β”‚
β”‚  β”‚ Client  │──────>β”‚   API   │──────>β”‚   AWS    β”‚      β”‚
β”‚  β”‚         β”‚<──────│ Gateway β”‚<──────│ Service  β”‚      β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜       β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜       β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜      β”‚
β”‚  β€’ With VTL mapping templates                            β”‚
β”‚                                                           β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Lambda Proxy Integration Event Structure

{
  "resource": "/users/{userId}",
  "path": "/users/123",
  "httpMethod": "GET",
  "headers": {
    "Accept": "application/json",
    "Host": "api.example.com"
  },
  "queryStringParameters": {
    "page": "1"
  },
  "pathParameters": {
    "userId": "123"
  },
  "stageVariables": {
    "environment": "prod"
  },
  "body": null,
  "isBase64Encoded": false
}

API Gateway Authorization

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚          API Gateway Authorization Methods                β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

1. IAM Authorization
   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”    SigV4 Signed Request    β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
   β”‚ Client │──────────────────────────>  β”‚ API Gateway β”‚
   β””β”€β”€β”€β”€β”€β”€β”€β”€β”˜    (IAM Credentials)        β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

2. Lambda Authorizer (Custom)
   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”    Token/Request Params    β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
   β”‚ Client │──────────────────────────> β”‚ API Gateway β”‚
   β””β”€β”€β”€β”€β”€β”€β”€β”€β”˜                             β””β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”˜
                                                 β”‚
                                                 β–Ό
                                          β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
                                          β”‚   Lambda    β”‚
                                          β”‚ Authorizer  β”‚
                                          β””β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”˜
                                                 β”‚
                                          Returns IAM Policy

3. Cognito User Pool
   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”         JWT Token         β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
   β”‚ Client │──────────────────────────> β”‚ API Gateway β”‚
   β””β”€β”€β”€β”€β”€β”€β”€β”€β”˜    (from Cognito login)    β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

4. API Keys + Usage Plans
   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”      x-api-key Header      β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
   β”‚ Client │──────────────────────────> β”‚ API Gateway β”‚
   β””β”€β”€β”€β”€β”€β”€β”€β”€β”˜    (Rate limiting)          β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

API Gateway Stages & Deployment

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚           API Gateway Stages                              β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

API Definition
     β”‚
     β”œβ”€β”€β”€ Deployment 1
     β”‚         β”‚
     β”‚         β”œβ”€β”€β”€ Stage: dev
     β”‚         β”‚    URL: https://api.example.com/dev
     β”‚         β”‚    Variables: { lambdaArn: "arn:...dev" }
     β”‚         β”‚
     β”‚         β”œβ”€β”€β”€ Stage: test
     β”‚         β”‚    URL: https://api.example.com/test
     β”‚         β”‚    Variables: { lambdaArn: "arn:...test" }
     β”‚         β”‚
     β”‚         └─── Stage: prod
     β”‚              URL: https://api.example.com/prod
     β”‚              Variables: { lambdaArn: "arn:...prod" }
     β”‚              Caching: Enabled (TTL: 300s)
     β”‚
     └─── Deployment 2 (new version)
               β”‚
               └─── Stage: v2
                    URL: https://api.example.com/v2

API Gateway Caching

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚              API Gateway Cache Flow                       β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Request 1 (Cache Miss)
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”         β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚ Client │────────>β”‚ API Gateway │────────>β”‚  Lambda  β”‚
β”‚        β”‚         β”‚   [Cache]   β”‚         β”‚          β”‚
β”‚        β”‚<────────│    Empty    β”‚<────────│          β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
                        β”‚
                        └─ Store in cache (TTL: 300s)

Request 2 (Cache Hit)
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”         β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         
β”‚ Client │────────>β”‚ API Gateway β”‚         
β”‚        β”‚         β”‚   [Cache]   β”‚ (No Lambda call!)
β”‚        β”‚<────────│  βœ… Hit!    β”‚         
β””β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         

Cache Invalidation:
β€’ Client sends: Cache-Control: max-age=0
β€’ Requires authorization checkbox enabled

πŸ“¨ SQS (Simple Queue Service)

Queue Types Comparison

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚          Standard Queue vs FIFO Queue                     β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                                           β”‚
β”‚  STANDARD QUEUE                                          β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”       β”‚
β”‚  β”‚  [Msg1] [Msg2] [Msg3] [Msg4] [Msg5]          β”‚       β”‚
β”‚  β”‚    ↓      ↓      ↓      ↓      ↓             β”‚       β”‚
β”‚  β”‚  Order NOT guaranteed                         β”‚       β”‚
β”‚  β”‚  Delivery: At-least-once (possible duplicates)β”‚       β”‚
β”‚  β”‚  Throughput: Unlimited                         β”‚       β”‚
β”‚  β”‚  Use: High throughput, order doesn't matter   β”‚       β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜       β”‚
β”‚                                                           β”‚
β”‚  FIFO QUEUE (.fifo suffix required)                      β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”       β”‚
β”‚  β”‚  [Msg1] β†’ [Msg2] β†’ [Msg3] β†’ [Msg4] β†’ [Msg5] β”‚       β”‚
β”‚  β”‚    ↓        ↓        ↓        ↓        ↓     β”‚       β”‚
β”‚  β”‚  Order GUARANTEED (FIFO)                      β”‚       β”‚
β”‚  β”‚  Delivery: Exactly-once (no duplicates)       β”‚       β”‚
β”‚  β”‚  Throughput: 300 TPS (3000 with batching)     β”‚       β”‚
β”‚  β”‚  Use: Order critical, financial transactions  β”‚       β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜       β”‚
β”‚                                                           β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

SQS Message Lifecycle

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚              SQS Message Lifecycle                        β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Producer                  SQS Queue                Consumer
   β”‚                         β”‚                         β”‚
   β”‚ 1. SendMessage         β”‚                         β”‚
   β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€>β”‚                         β”‚
   β”‚                         β”‚                         β”‚
   β”‚                     [Message]                     β”‚
   β”‚                    Retention: 4 days              β”‚
   β”‚                         β”‚                         β”‚
   β”‚                         β”‚ 2. ReceiveMessage       β”‚
   β”‚                         β”‚<─────────────────────────
   β”‚                         β”‚                         β”‚
   β”‚                    Visibility Timeout             β”‚
   β”‚                    (Hidden: 30s)                  β”‚
   β”‚                         β”‚                         β”‚
   β”‚                         β”‚ 3. Processing...        β”‚
   β”‚                         β”‚                         β”‚
   β”‚                         β”‚ 4. DeleteMessage        β”‚
   β”‚                         β”‚<─────────────────────────
   β”‚                         β”‚                         β”‚
   β”‚                    Message Deleted                β”‚
   β”‚                         β”‚                         β”‚

Visibility Timeout Expiry (if not deleted):
   β”‚                         β”‚                         
   β”‚                    Message becomes                
   β”‚                    visible again                  
   β”‚                    (retry mechanism)              

Long Polling vs Short Polling

SHORT POLLING (WaitTimeSeconds = 0)
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”        β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚Consumer│───────>β”‚   SQS   β”‚
β”‚        β”‚ Query  β”‚  Queue  β”‚
β”‚        β”‚<───────│ (Empty) β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”˜ Instantβ””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
           Response
β€’ Returns immediately (even if empty)
β€’ More API calls = Higher cost
β€’ May miss messages

LONG POLLING (WaitTimeSeconds = 1-20) ⭐ Recommended
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”        β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚Consumer│───────>β”‚   SQS   β”‚
β”‚        β”‚ Wait   β”‚  Queue  β”‚
β”‚        β”‚ up to  β”‚ (Wait..)β”‚
β”‚        β”‚ 20s    β”‚         β”‚
β”‚        β”‚<───────│[Message]β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”˜        β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
β€’ Waits until message arrives or timeout
β€’ Fewer API calls = Lower cost
β€’ More efficient

SQS Extended Client Library

Large Message Handling (> 256 KB, up to 2 GB)

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚  Producer                                                β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                                           β”‚
β”‚  β”‚ Large    β”‚  1. Upload to S3                          β”‚
β”‚  β”‚ Payload  │─────────────────────┐                    β”‚
β”‚  β”‚ (500MB)  β”‚                     β–Ό                     β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜              β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                 β”‚
β”‚                            β”‚    S3    β”‚                 β”‚
β”‚       β”‚                    β”‚  Bucket  β”‚                 β”‚
β”‚       β”‚                    β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                 β”‚
β”‚       β”‚ 2. Send S3 pointer       β”‚                      β”‚
β”‚       β–Ό                          β”‚                      β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                    β”‚                      β”‚
β”‚  β”‚   SQS    β”‚                    β”‚                      β”‚
β”‚  β”‚  Queue   β”‚                    β”‚                      β”‚
β”‚  β”‚ (S3 ref) β”‚                    β”‚                      β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                    β”‚                      β”‚
β”‚       β”‚                          β”‚                      β”‚
β”‚       β”‚ 3. Receive pointer       β”‚                      β”‚
β”‚       β–Ό                          β”‚                      β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                    β”‚                      β”‚
β”‚  β”‚Consumer  β”‚  4. Download       β”‚                      β”‚
β”‚  β”‚          β”‚<β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                      β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜                                           β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

πŸ“£ SNS (Simple Notification Service)

SNS Pub/Sub Pattern

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚              SNS Topic Fan-Out Pattern                    β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

                    β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
                    β”‚  Publisher  β”‚
                    β””β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”˜
                           β”‚
                           β”‚ Publish
                           β–Ό
                    β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
                    β”‚  SNS Topic  β”‚
                    β””β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”˜
                           β”‚
                ┏━━━━━━━━━━┻━━━━━━━━━━┓
                β–Ό          β–Ό           β–Ό
          β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β” β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β” β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”
          β”‚ Lambda  β”‚ β”‚   SQS   β”‚ β”‚  Email  β”‚
          β”‚Function β”‚ β”‚  Queue  β”‚ β”‚   Sub   β”‚
          β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜ β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜ β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
                β”‚          β”‚           β”‚
                β–Ό          β–Ό           β–Ό
          [Process]   [Decouple]  [Notify User]

Benefits:
β€’ 1 message β†’ Multiple subscribers
β€’ Decouple services
β€’ Parallel processing

πŸ”‘ KMS (Key Management Service)

KMS Key Types

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚                   KMS Key Types                           β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                                           β”‚
β”‚  AWS Managed Keys                                        β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”‚
β”‚  β”‚ aws/s3, aws/lambda, aws/rds                 β”‚         β”‚
β”‚  β”‚ β€’ Free                                      β”‚         β”‚
β”‚  β”‚ β€’ Auto rotation (every 3 years)            β”‚         β”‚
β”‚  β”‚ β€’ Cannot modify                             β”‚         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β”‚
β”‚                                                           β”‚
β”‚  Customer Managed Keys (CMK)                             β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”‚
β”‚  β”‚ You create and manage                       β”‚         β”‚
β”‚  β”‚ β€’ $1/month                                  β”‚         β”‚
β”‚  β”‚ β€’ Optional auto rotation (annual)           β”‚         β”‚
β”‚  β”‚ β€’ Full control over policies                β”‚         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β”‚
β”‚                                                           β”‚
β”‚  Key Types:                                              β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”            β”‚
β”‚  β”‚    Symmetric     β”‚  β”‚   Asymmetric     β”‚            β”‚
β”‚  β”‚   (256-bit)      β”‚  β”‚  (RSA/ECC)       β”‚            β”‚
β”‚  β”‚                  β”‚  β”‚                  β”‚            β”‚
β”‚  β”‚ β€’ Single key     β”‚  β”‚ β€’ Public/Private β”‚            β”‚
β”‚  β”‚ β€’ Encrypt/Decryptβ”‚  β”‚ β€’ Sign/Verify    β”‚            β”‚
β”‚  β”‚ β€’ Most common βœ… β”‚  β”‚ β€’ Cannot import  β”‚            β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜            β”‚
β”‚                                                           β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Data Key Generation Flow

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚          KMS Envelope Encryption Pattern                  β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Application                KMS                  S3
    β”‚                      β”‚                     β”‚
    β”‚ 1. GenerateDataKey   β”‚                     β”‚
    β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€>β”‚                     β”‚
    β”‚                      β”‚                     β”‚
    β”‚ 2. Returns:          β”‚                     β”‚
    β”‚    - Plaintext Key   β”‚                     β”‚
    β”‚    - Encrypted Key   β”‚                     β”‚
    β”‚<──────────────────────                     β”‚
    β”‚                      β”‚                     β”‚
    β”‚ 3. Encrypt data      β”‚                     β”‚
    β”‚    with plaintext    β”‚                     β”‚
    β”‚    key (locally)     β”‚                     β”‚
    β”‚                      β”‚                     β”‚
    β”‚ 4. Upload:           β”‚                     β”‚
    β”‚    - Encrypted data  β”‚                     β”‚
    β”‚    - Encrypted key   β”‚                     β”‚
    β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€>β”‚
    β”‚                      β”‚                     β”‚
    β”‚ 5. Delete plaintext  β”‚                     β”‚
    β”‚    key from memory   β”‚                     β”‚
    β”‚                      β”‚                     β”‚

Download & Decrypt:
    β”‚ 1. Get encrypted     β”‚                     β”‚
    β”‚    data + key        β”‚                     β”‚
    β”‚<────────────────────────────────────────────
    β”‚                      β”‚                     β”‚
    β”‚ 2. Decrypt key       β”‚                     β”‚
    β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€>β”‚                     β”‚
    β”‚                      β”‚                     β”‚
    β”‚ 3. Returns plaintext β”‚                     β”‚
    β”‚    data key          β”‚                     β”‚
    β”‚<──────────────────────                     β”‚
    β”‚                      β”‚                     β”‚
    β”‚ 4. Decrypt data      β”‚                     β”‚
    β”‚    locally           β”‚                     β”‚

Key APIs:

  • GenerateDataKey: Returns plaintext + encrypted key
  • GenerateDataKeyWithoutPlaintext: Returns only encrypted key (decrypt later)
  • Encrypt / Decrypt: Direct encryption (max 4 KB)

πŸ“¦ S3 (Simple Storage Service)

S3 Encryption Options

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚           S3 Server-Side Encryption (SSE)                 β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                                           β”‚
β”‚  SSE-S3 (Default, Simplest)                              β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”‚
β”‚  β”‚ AWS manages keys automatically              β”‚         β”‚
β”‚  β”‚ Header: x-amz-server-side-encryption:       β”‚         β”‚
β”‚  β”‚         AES256                               β”‚         β”‚
β”‚  β”‚ Use: Simple encryption, no key management   β”‚         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β”‚
β”‚                                                           β”‚
β”‚  SSE-KMS (Most Common) ⭐                                 β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”‚
β”‚  β”‚ Uses KMS keys (audit logs via CloudTrail)  β”‚         β”‚
β”‚  β”‚ Headers:                                     β”‚         β”‚
β”‚  β”‚   - x-amz-server-side-encryption: aws:kms   β”‚         β”‚
β”‚  β”‚   - x-amz-server-side-encryption-aws-       β”‚         β”‚
β”‚  β”‚     kms-key-id: <key-id>                    β”‚         β”‚
β”‚  β”‚ Use: Auditable encryption, key rotation     β”‚         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β”‚
β”‚                                                           β”‚
β”‚  SSE-C (Customer Provides Key)                           β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”‚
β”‚  β”‚ You provide key with EVERY request          β”‚         β”‚
β”‚  β”‚ Headers (ALL required):                     β”‚         β”‚
β”‚  β”‚   - customer-algorithm: AES256              β”‚         β”‚
β”‚  β”‚   - customer-key: <your-base64-key>         β”‚         β”‚
β”‚  β”‚   - customer-key-MD5: <md5-hash>            β”‚         β”‚
β”‚  β”‚ AWS does NOT store your key                 β”‚         β”‚
β”‚  β”‚ Use: Complete key control                   β”‚         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β”‚
β”‚                                                           β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

S3 Event Notifications

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚           S3 Event Notification Flow                      β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

                    S3 Bucket
                 β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
                 β”‚   Events:   β”‚
                 β”‚             β”‚
    Upload ────> β”‚ β€’ ObjectCreated
                 β”‚ β€’ ObjectRemoved
                 β”‚ β€’ ObjectRestore
                 β”‚ β€’ RRS Lost
                 β”‚             β”‚
                 β””β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”˜
                        β”‚
        ┏━━━━━━━━━━━━━━━┻━━━━━━━━━━━━━━━┓
        β–Ό               β–Ό                β–Ό
   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”    β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”     β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”
   β”‚  Lambda β”‚    β”‚   SNS   β”‚     β”‚   SQS   β”‚
   β”‚Function β”‚    β”‚  Topic  β”‚     β”‚  Queue  β”‚
   β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜    β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜     β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
        β”‚               β”‚                β”‚
        β–Ό               β–Ό                β–Ό
   [Process]      [Notify]         [Queue Work]

S3 Object Lambda

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚         S3 Object Lambda (Transform on-the-fly)           β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Application                  S3 Object Lambda          S3 Bucket
    β”‚                             β”‚                        β”‚
    β”‚ 1. GET request              β”‚                        β”‚
    β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€>β”‚                        β”‚
    β”‚                             β”‚                        β”‚
    β”‚                             β”‚ 2. Retrieve object     β”‚
    β”‚                             β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€>β”‚
    β”‚                             β”‚                        β”‚
    β”‚                             β”‚ 3. Original data       β”‚
    β”‚                             β”‚<────────────────────────
    β”‚                             β”‚                        β”‚
    β”‚                     β”Œβ”€β”€β”€β”€β”€β”€β”€β”΄β”€β”€β”€β”€β”€β”€β”€β”€β”              β”‚
    β”‚                     β”‚ Lambda Function β”‚              β”‚
    β”‚                     β”‚ β€’ Redact PII    β”‚              β”‚
    β”‚                     β”‚ β€’ Resize images β”‚              β”‚
    β”‚                     β”‚ β€’ Filter data   β”‚              β”‚
    β”‚                     β””β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”˜              β”‚
    β”‚                             β”‚                        β”‚
    β”‚ 4. Transformed data         β”‚                        β”‚
    β”‚<─────────────────────────────                        β”‚
    β”‚                             β”‚                        β”‚

Use Cases:
β€’ Redact sensitive data (PII)
β€’ Resize/watermark images
β€’ Convert file formats
β€’ Enrich data with metadata

S3 Cross-Region Replication

Source Bucket (us-east-1)        Destination Bucket (eu-west-1)
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”        β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚ βœ… Versioning ON      β”‚        β”‚ βœ… Versioning ON      β”‚
β”‚                       β”‚        β”‚                       β”‚
β”‚  New Object Upload    β”‚        β”‚                       β”‚
β”‚         β”‚             β”‚        β”‚                       β”‚
β”‚         β–Ό             β”‚        β”‚                       β”‚
β”‚   [object.txt]────────┼───────>β”‚  [object.txt]         β”‚
β”‚                       β”‚        β”‚                       β”‚
β”‚   IAM Role with       β”‚        β”‚                       β”‚
β”‚   replication perms   β”‚        β”‚                       β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜        β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Requirements:
βœ… Versioning enabled on both buckets
βœ… Buckets in different regions
βœ… IAM role with replication permissions
βœ… Replication configuration on source bucket

πŸ“Š CloudWatch

CloudWatch Metrics Resolution

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚          CloudWatch Metrics Resolution                    β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                                           β”‚
β”‚  Standard Resolution (AWS Services)                      β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”‚
β”‚  β”‚  Metric points every 1 minute               β”‚         β”‚
β”‚  β”‚  β”œβ”€ 0s ─ 60s ─ 120s ─ 180s ─ 240s ─        β”‚         β”‚
β”‚  β”‚  └─ [●]  [●]   [●]    [●]    [●]            β”‚         β”‚
β”‚  β”‚  Retention: 15 months                       β”‚         β”‚
β”‚  β”‚  Cost: Free for AWS services                β”‚         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β”‚
β”‚                                                           β”‚
β”‚  High Resolution (Custom Metrics)                        β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”‚
β”‚  β”‚  Metric points every 1 second               β”‚         β”‚
β”‚  β”‚  β”œβ”€ 0s ─ 1s ─ 2s ─ 3s ─ 4s ─ 5s ─          β”‚         β”‚
β”‚  β”‚  └─ [●] [●] [●] [●] [●] [●]                 β”‚         β”‚
β”‚  β”‚  Use: Real-time monitoring                  β”‚         β”‚
β”‚  β”‚  Cost: Higher (more data points)            β”‚         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β”‚
β”‚                                                           β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

CloudWatch Alarms

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚         CloudWatch Alarm Configuration                    β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Metric: CPUUtilization
Period: 5 minutes (300 seconds)
Evaluation Periods: 3
Datapoints to Alarm: 2

Timeline:
β”Œβ”€β”€β”€β”€β”¬β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”
β”‚ P1 β”‚ P2 β”‚ P3 β”‚ P4 β”‚ P5 β”‚  Periods
β”œβ”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”€
β”‚ 45%β”‚ 85%β”‚ 90%β”‚ 60%β”‚ 88%β”‚  CPU Values
β”œβ”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”€
β”‚ OK β”‚ ⚠️ β”‚ ⚠️ β”‚ OK β”‚ ⚠️ β”‚  Status (threshold: 80%)
β””β”€β”€β”€β”€β”΄β”€β”€β”€β”€β”΄β”€β”€β”€β”€β”΄β”€β”€β”€β”€β”΄β”€β”€β”€β”€β”˜
        └──Eval Periodsβ”€β”€β”˜
          (last 3)

Evaluation at P5:
β€’ Last 3 periods: [P3=90%, P4=60%, P5=88%]
β€’ Breaching datapoints: 2 (P3, P5)
β€’ Threshold: 2 breaching required
β€’ Result: πŸ”” ALARM triggered!

Analogy: Checking Fever 🌑️
β€’ Period: Check temperature every 1 hour
β€’ Evaluation Periods: Look at last 5 readings
β€’ Datapoints to Alarm: At least 3 must be fever
β€’ Action: Call doctor if 3+ high readings

CloudWatch Embedded Metric Format (EMF)

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚      CloudWatch EMF (Extract Metrics from Logs)           β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Lambda Function
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚  const metrics = require(              β”‚
β”‚    'aws-embedded-metrics'              β”‚
β”‚  );                                    β”‚
β”‚                                        β”‚
β”‚  exports.handler = async (event) => {  β”‚
β”‚    const metric = metrics.createMetricβ”‚
β”‚      Namespace('MyApp');               β”‚
β”‚                                        β”‚
β”‚    metric.putMetric(                   β”‚
β”‚      'ProcessingTime',                 β”‚
β”‚      150,  // milliseconds             β”‚
β”‚      'Milliseconds'                    β”‚
β”‚    );                                  β”‚
β”‚                                        β”‚
β”‚    metric.setProperty('orderId', 123); β”‚
β”‚  };                                    β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
                 β”‚
                 β–Ό
         CloudWatch Logs
         β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
         β”‚ Structured  β”‚
         β”‚ JSON logs   β”‚
         β””β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”˜
                β”‚
                β”‚ Auto-parsed
                β–Ό
         CloudWatch Metrics
         β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
         β”‚ Namespace: MyApp β”‚
         β”‚ Metric:          β”‚
         β”‚ ProcessingTime   β”‚
         β”‚ β”œβ”€ Value: 150ms  β”‚
         β”‚ └─ Dimension:    β”‚
         β”‚    orderId=123   β”‚
         β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Benefits:
βœ… No PutMetricData API calls
βœ… Real-time metrics from logs
βœ… Queryable in Logs Insights
βœ… Automatic CloudWatch Metrics creation

πŸ” X-Ray

X-Ray Architecture

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚              AWS X-Ray Tracing Flow                       β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Client Request
     β”‚
     β–Ό
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚  API Gateway    β”‚ ← Segment
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚ Trace ID:       β”‚
β”‚ 1-abc-def       β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”˜
         β”‚
         β–Ό
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚  Lambda Fn      β”‚ ← Segment
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚ Parent ID:      β”‚
β”‚ API Gateway     β”‚
β”‚                 β”‚
β”‚ β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β” β”‚
β”‚ β”‚ DynamoDB    β”‚ β”‚ ← Subsegment (namespace: aws)
β”‚ β”‚ Query       β”‚ β”‚
β”‚ β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜ β”‚
β”‚                 β”‚
β”‚ β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β” β”‚
β”‚ β”‚ External    β”‚ β”‚ ← Subsegment (namespace: remote)
β”‚ β”‚ HTTP Call   β”‚ β”‚
β”‚ β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜ β”‚
β”‚                 β”‚
β”‚ β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β” β”‚
β”‚ β”‚ Business    β”‚ β”‚ ← Subsegment (namespace: local)
β”‚ β”‚ Logic       β”‚ β”‚
β”‚ β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜ β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”˜
         β”‚
         β–Ό
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚  DynamoDB       β”‚ ← Segment
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Hierarchy:
β€’ Trace: End-to-end request (all services)
β€’ Segment: Individual service (API Gateway, Lambda)
β€’ Subsegment: Downstream calls within service

X-Ray Annotations vs Metadata

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚        X-Ray Annotations vs Metadata                      β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                                           β”‚
β”‚  Annotations (Searchable, Indexed) ⭐                     β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”‚
β”‚  β”‚  Key-Value pairs (up to 50 per trace)      β”‚         β”‚
β”‚  β”‚                                             β”‚         β”‚
β”‚  β”‚  Example:                                   β”‚         β”‚
β”‚  β”‚  {                                          β”‚         β”‚
β”‚  β”‚    "user_id": "12345",                      β”‚         β”‚
β”‚  β”‚    "environment": "prod",                   β”‚         β”‚
β”‚  β”‚    "feature_flag": "enabled"                β”‚         β”‚
β”‚  β”‚  }                                          β”‚         β”‚
β”‚  β”‚                                             β”‚         β”‚
β”‚  β”‚  βœ… Use for: Filtering traces in console   β”‚         β”‚
β”‚  β”‚  βœ… Use for: GetTraceSummaries API          β”‚         β”‚
β”‚  β”‚  βœ… Indexed for fast queries                β”‚         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β”‚
β”‚                                                           β”‚
β”‚  Metadata (Not Indexed, Debugging Only)                  β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”‚
β”‚  β”‚  Any data type (objects, arrays, etc.)     β”‚         β”‚
β”‚  β”‚                                             β”‚         β”‚
β”‚  β”‚  Example:                                   β”‚         β”‚
β”‚  β”‚  {                                          β”‚         β”‚
β”‚  β”‚    "request_body": {...},                   β”‚         β”‚
β”‚  β”‚    "config": {...},                         β”‚         β”‚
β”‚  β”‚    "debug_info": [...]                      β”‚         β”‚
β”‚  β”‚  }                                          β”‚         β”‚
β”‚  β”‚                                             β”‚         β”‚
β”‚  β”‚  βœ… Use for: Debugging details              β”‚         β”‚
β”‚  β”‚  ❌ NOT searchable in console               β”‚         β”‚
β”‚  β”‚  ❌ NOT indexed                             β”‚         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β”‚
β”‚                                                           β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

X-Ray Daemon

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚              X-Ray Daemon Architecture                    β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

EC2 / ECS Instance
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚                                            β”‚
β”‚  Application                               β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                          β”‚
β”‚  β”‚  X-Ray SDK   β”‚                          β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”˜                          β”‚
β”‚         β”‚                                   β”‚
β”‚         β”‚ UDP 2000                          β”‚
β”‚         β–Ό                                   β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”                          β”‚
β”‚  β”‚  X-Ray       β”‚                          β”‚
β”‚  β”‚  Daemon      β”‚                          β”‚
β”‚  β”‚              β”‚                          β”‚
β”‚  β”‚  β€’ Buffers   β”‚                          β”‚
β”‚  β”‚  β€’ Batches   β”‚                          β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”˜                          β”‚
β”‚         β”‚                                   β”‚
β”‚         β”‚ HTTPS                             β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
          β”‚
          β–Ό
    β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
    β”‚   X-Ray API  β”‚
    β”‚   (AWS)      β”‚
    β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Lambda: ❌ No daemon needed (built-in)
EC2/ECS: βœ… Daemon required
IAM Policy: AWSXRayDaemonWriteAccess

Environment Variables:
β€’ _X_AMZN_TRACE_ID: Trace context
β€’ AWS_XRAY_CONTEXT_MISSING: Error handling

🐳 ECS (Elastic Container Service)

ECS Task Placement

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚           ECS Task Placement Strategies                   β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

BINPACK (Minimize Instances)
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚ Instance 1       Instance 2    Instance 3  β”‚
β”‚ [β–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆ]       [β–ˆβ–ˆβ–‘β–‘]         [β–‘β–‘β–‘β–‘]     β”‚
β”‚ 80% CPU          20% CPU        0% CPU     β”‚
β”‚ 8 tasks          2 tasks        0 tasks    β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚ β€’ Fill instances before launching new      β”‚
β”‚ β€’ Cost optimization βœ…                     β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

SPREAD (Distribute Evenly)
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚  AZ: us-east-1a    AZ: us-east-1b          β”‚
β”‚  [β–ˆβ–ˆβ–ˆβ–ˆ]            [β–ˆβ–ˆβ–ˆβ–ˆ]                  β”‚
β”‚  5 tasks           5 tasks                 β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚ β€’ High availability βœ…                     β”‚
β”‚ β€’ Spread by: AZ, instance-id, custom attr  β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

RANDOM (Random Placement)
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚ Instance 1       Instance 2    Instance 3  β”‚
β”‚ [β–ˆβ–ˆβ–ˆβ–‘]           [β–ˆβ–ˆβ–ˆβ–ˆβ–ˆ]        [β–ˆβ–ˆβ–‘β–‘]     β”‚
β”‚ Random           Random         Random     β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

ECS Port Mappings

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚            ECS Task Definition Port Mapping               β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

EC2 Instance
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚                                               β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”     β”‚
β”‚  β”‚ Task 1                              β”‚     β”‚
β”‚  β”‚ β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”     β”‚     β”‚
β”‚  β”‚ β”‚ Container                   β”‚     β”‚     β”‚
β”‚  β”‚ β”‚ containerPort: 80 ────┐     β”‚     β”‚     β”‚
β”‚  β”‚ β”‚ hostPort: 32768 β—„β”€β”€β”€β”€β”€β”˜     β”‚     β”‚     β”‚
β”‚  β”‚ β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜     β”‚     β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜     β”‚
β”‚                                               β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”     β”‚
β”‚  β”‚ Task 2                              β”‚     β”‚
β”‚  β”‚ β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”     β”‚     β”‚
β”‚  β”‚ β”‚ Container                   β”‚     β”‚     β”‚
β”‚  β”‚ β”‚ containerPort: 80 ────┐     β”‚     β”‚     β”‚
β”‚  β”‚ β”‚ hostPort: 32769 β—„β”€β”€β”€β”€β”€β”˜     β”‚     β”‚     β”‚
β”‚  β”‚ β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜     β”‚     β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜     β”‚
β”‚                                               β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Dynamic Port Mapping:
β€’ Set hostPort: 0 (ECS assigns random port)
β€’ Allows multiple tasks per instance
β€’ ALB uses dynamic port discovery

awsvpc Network Mode:
β€’ hostPort = containerPort (or leave blank)
β€’ Task gets own ENI with private IP

ECS IAM Roles

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚              ECS IAM Roles (Best Practice)                β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚ Task Definition 1: Web Service             β”‚
β”‚ β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”     β”‚
β”‚ β”‚ Task Role: WebServiceRole          β”‚     β”‚
β”‚ β”‚ Permissions:                        β”‚     β”‚
β”‚ β”‚ β€’ S3: Read/Write to web-bucket      β”‚     β”‚
β”‚ β”‚ β€’ DynamoDB: Full access to UserTableβ”‚     β”‚
β”‚ β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜     β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚ Task Definition 2: Analytics Service       β”‚
β”‚ β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”     β”‚
β”‚ β”‚ Task Role: AnalyticsRole            β”‚     β”‚
β”‚ β”‚ Permissions:                        β”‚     β”‚
β”‚ β”‚ β€’ S3: Read from analytics-bucket    β”‚     β”‚
β”‚ β”‚ β€’ Athena: Query execution           β”‚     β”‚
β”‚ β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜     β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Best Practice:
βœ… One IAM role per task definition
βœ… Principle of least privilege
βœ… No shared roles across services

πŸ“¦ Elastic Beanstalk

Deployment Strategies

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚       Elastic Beanstalk Deployment Strategies             β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                                           β”‚
β”‚  All-at-Once (Fastest, but downtime)                     β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”‚
β”‚  β”‚ [v1] [v1] [v1] [v1]                         β”‚         β”‚
β”‚  β”‚   ↓    ↓    ↓    ↓    All update at once   β”‚         β”‚
β”‚  β”‚ [v2] [v2] [v2] [v2]                         β”‚         β”‚
β”‚  β”‚ β€’ Downtime: YES ❌                           β”‚         β”‚
β”‚  β”‚ β€’ Rollback: Redeploy                        β”‚         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β”‚
β”‚                                                           β”‚
β”‚  Rolling (Gradual, partial capacity)                     β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”‚
β”‚  β”‚ [v1] [v1] [v1] [v1]                         β”‚         β”‚
β”‚  β”‚   ↓    ↓                                    β”‚         β”‚
β”‚  β”‚ [v2] [v2] [v1] [v1]  (Batch 1)              β”‚         β”‚
β”‚  β”‚             ↓    ↓                          β”‚         β”‚
β”‚  β”‚ [v2] [v2] [v2] [v2]  (Batch 2)              β”‚         β”‚
β”‚  β”‚ β€’ Downtime: Partial (reduced capacity)      β”‚         β”‚
β”‚  β”‚ β€’ Rollback: Redeploy                        β”‚         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β”‚
β”‚                                                           β”‚
β”‚  Rolling with Additional Batch                           β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”‚
β”‚  β”‚ [v1] [v1] [v1] [v1] +[v2] [v2]              β”‚         β”‚
β”‚  β”‚ (Launch new first, maintain capacity)       β”‚         β”‚
β”‚  β”‚ β€’ Downtime: NO βœ…                            β”‚         β”‚
β”‚  β”‚ β€’ Cost: Temporary extra instances           β”‚         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β”‚
β”‚                                                           β”‚
β”‚  Immutable (Safest, full rollback)                       β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”‚
β”‚  β”‚ Environment A: [v1] [v1] [v1] [v1]          β”‚         β”‚
β”‚  β”‚ New ASG:       [v2] [v2] [v2] [v2]          β”‚         β”‚
β”‚  β”‚ If healthy: Swap, terminate old ASG         β”‚         β”‚
β”‚  β”‚ If unhealthy: Terminate new ASG             β”‚         β”‚
β”‚  β”‚ β€’ Downtime: NO βœ…                            β”‚         β”‚
β”‚  β”‚ β€’ Rollback: Easy βœ…                          β”‚         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β”‚
β”‚                                                           β”‚
β”‚  Blue/Green (Zero downtime)                              β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”‚
β”‚  β”‚ Blue Env (v1) ◄────── Traffic              β”‚         β”‚
β”‚  β”‚ Green Env (v2)        (Idle)                β”‚         β”‚
β”‚  β”‚                                             β”‚         β”‚
β”‚  β”‚ Swap CNAME                                  β”‚         β”‚
β”‚  β”‚                                             β”‚         β”‚
β”‚  β”‚ Blue Env (v1)         (Idle)                β”‚         β”‚
β”‚  β”‚ Green Env (v2) ◄───── Traffic              β”‚         β”‚
β”‚  β”‚ β€’ Downtime: NO βœ…                            β”‚         β”‚
β”‚  β”‚ β€’ Rollback: Swap CNAME back βœ…              β”‚         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β”‚
β”‚                                                           β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Elastic Beanstalk Configuration Files

Project Structure:
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚ my-app/                                β”‚
β”‚ β”œβ”€β”€ .ebextensions/                     β”‚
β”‚ β”‚   β”œβ”€β”€ 01-packages.config             β”‚
β”‚ β”‚   β”œβ”€β”€ 02-environment.config          β”‚
β”‚ β”‚   └── 03-scaling.config              β”‚
β”‚ β”œβ”€β”€ env.yaml                           β”‚
β”‚ β”œβ”€β”€ application.zip                    β”‚
β”‚ └── ...                                β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

env.yaml (Environment manifest):
---
AWSConfigurationTemplateVersion: 1.1.0.0
EnvironmentName: production
SolutionStack: "64bit Amazon Linux 2 v3.x"
EnvironmentLinks:
  "WORKERQUEUE": "worker-env"

.ebextensions/*.config (Resource settings):
option_settings:
  - namespace: aws:elasticbeanstalk:environment
    option_name: EnvironmentType
    value: LoadBalanced

πŸš€ CodeDeploy

Deployment Types by Platform

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚         CodeDeploy Deployment Configurations              β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                                           β”‚
β”‚  EC2 / On-Premises                                       β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”‚
β”‚  β”‚ β€’ In-Place                                  β”‚         β”‚
β”‚  β”‚   └─ Stop app β†’ Install β†’ Start            β”‚         β”‚
β”‚  β”‚                                             β”‚         β”‚
β”‚  β”‚ β€’ Blue/Green                                β”‚         β”‚
β”‚  β”‚   └─ New instances β†’ Test β†’ Swap           β”‚         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β”‚
β”‚                                                           β”‚
β”‚  Lambda                                                  β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”‚
β”‚  β”‚ β€’ Canary (2 increments)                     β”‚         β”‚
β”‚  β”‚   └─ 10% β†’ Wait β†’ 90%                       β”‚         β”‚
β”‚  β”‚                                             β”‚         β”‚
β”‚  β”‚ β€’ Linear (Equal increments)                 β”‚         β”‚
β”‚  β”‚   └─ 10% every 10 min                       β”‚         β”‚
β”‚  β”‚                                             β”‚         β”‚
β”‚  β”‚ β€’ All-at-Once                               β”‚         β”‚
β”‚  β”‚   └─ 100% immediately                       β”‚         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β”‚
β”‚                                                           β”‚
β”‚  ECS                                                     β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”‚
β”‚  β”‚ β€’ Blue/Green                                β”‚         β”‚
β”‚  β”‚   └─ New task set β†’ Test β†’ Switch traffic  β”‚         β”‚
β”‚  β”‚                                             β”‚         β”‚
β”‚  β”‚ β€’ Canary / Linear                           β”‚         β”‚
β”‚  β”‚   └─ Gradual traffic shifting               β”‚         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β”‚
β”‚                                                           β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

CodeDeploy Lifecycle Hooks

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚         CodeDeploy Lifecycle Events                       β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

EC2 / On-Premises:
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚ ApplicationStop                          β”‚
β”‚   ↓                                      β”‚
β”‚ DownloadBundle                           β”‚
β”‚   ↓                                      β”‚
β”‚ BeforeInstall                            β”‚
β”‚   ↓                                      β”‚
β”‚ Install                                  β”‚
β”‚   ↓                                      β”‚
β”‚ AfterInstall                             β”‚
β”‚   ↓                                      β”‚
β”‚ ApplicationStart                         β”‚
β”‚   ↓                                      β”‚
β”‚ ValidateService                          β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Lambda:
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚ BeforeAllowTraffic                       β”‚
β”‚   ↓                                      β”‚
β”‚ AllowTraffic (Automatic)                 β”‚
β”‚   ↓                                      β”‚
β”‚ AfterAllowTraffic                        β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

ECS:
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚ BeforeInstall                            β”‚
β”‚   ↓                                      β”‚
β”‚ Install (Automatic)                      β”‚
β”‚   ↓                                      β”‚
β”‚ AfterInstall                             β”‚
β”‚   ↓                                      β”‚
β”‚ AfterAllowTestTraffic                    β”‚
β”‚   ↓                                      β”‚
β”‚ BeforeAllowTraffic                       β”‚
β”‚   ↓                                      β”‚
β”‚ AllowTraffic (Automatic)                 β”‚
β”‚   ↓                                      β”‚
β”‚ AfterAllowTraffic                        β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Canary Deployment Example

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚      Canary10Percent10Minutes Deployment                  β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Time: 0 min
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚ Original Version (100%)                 β”‚
β”‚ [β–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆ]     β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Time: 0 min (immediate)
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚ Original (90%)  β”‚ New Version (10%)    β”‚
β”‚ [β–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–‘β–‘β–‘β–‘]           β”‚
β”‚                                        β”‚
β”‚ Monitor for errors...                  β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Time: 10 min (if healthy)
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚ New Version (100%)                      β”‚
β”‚ [β–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆ]     β”‚
β”‚                                        β”‚
β”‚ Deployment Complete! βœ…                 β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

If errors detected:
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚ Automatic Rollback                      β”‚
β”‚ [β–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆβ–ˆ]     β”‚
β”‚ ← Back to Original Version             β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

☁️ CloudFormation

CloudFormation Template Structure

AWSTemplateFormatVersion: '2010-09-09'
Description: 'My CloudFormation Stack'

Parameters:
  EnvironmentType:
    Type: String
    Default: dev
    AllowedValues: [dev, test, prod]

Resources:
  MyBucket:
    Type: AWS::S3::Bucket
    Properties:
      BucketName: !Sub 'my-bucket-${EnvironmentType}'

Outputs:
  BucketName:
    Value: !Ref MyBucket
    Export:
      Name: !Sub '${AWS::StackName}-BucketName'

CloudFormation StackSets

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚           CloudFormation StackSets                        β”‚
β”‚    (Deploy to Multiple Accounts/Regions)                  β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Administrator Account
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚  StackSet                            β”‚
β”‚  β”œβ”€ Template: app-stack.yaml        β”‚
β”‚  β”œβ”€ Parameters: {...}                β”‚
β”‚  └─ Target Accounts: [123, 456, 789]β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
               β”‚
      ┏━━━━━━━━┻━━━━━━━━┓
      β–Ό                  β–Ό
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚ Account 123  β”‚   β”‚ Account 456  β”‚
β”‚ β”œβ”€ us-east-1 β”‚   β”‚ β”œβ”€ us-east-1 β”‚
β”‚ β”œβ”€ eu-west-1 β”‚   β”‚ β”œβ”€ eu-west-1 β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜   β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Operations:
β€’ Create: Deploy to all targets
β€’ Update: Update all stacks
β€’ Delete: Remove from all targets
β€’ Single Operation: Affects all accounts/regions

CloudFormation Drift Detection

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚         CloudFormation Drift Detection                    β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Template Definition           Actual Resource
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚ S3 Bucket:       β”‚         β”‚ S3 Bucket:       β”‚
β”‚ β€’ Versioning: ON β”‚   VS    β”‚ β€’ Versioning: OFFβ”‚
β”‚ β€’ Encryption: ON β”‚         β”‚ β€’ Encryption: OFFβ”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
         β”‚                            β”‚
         β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
                      β”‚
                      β–Ό
         β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
         β”‚ Drift Detected! ⚠️      β”‚
         β”‚ β€’ Versioning changed   β”‚
         β”‚ β€’ Encryption disabled  β”‚
         β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Use Case:
β€’ Detect manual changes outside CloudFormation
β€’ Maintain infrastructure compliance
β€’ Identify configuration drift

πŸ”§ SAM (Serverless Application Model)

SAM Template Structure

Transform: AWS::Serverless-2016-10-31  # Required!

Globals:  # Shared properties (optional)
  Function:
    Runtime: python3.9
    Timeout: 30

Resources:
  MyFunction:
    Type: AWS::Serverless::Function
    Properties:
      Handler: index.handler
      CodeUri: ./src
      Events:
        ApiEvent:
          Type: Api
          Properties:
            Path: /hello
            Method: get

  MyApi:
    Type: AWS::Serverless::Api
    Properties:
      StageName: prod

  MyTable:
    Type: AWS::Serverless::SimpleTable

SAM CLI Workflow

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚              SAM Development Workflow                     β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

1. Initialize
   $ sam init
   └─ Creates project template

2. Build
   $ sam build
   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
   β”‚ β€’ Compile code                 β”‚
   β”‚ β€’ Install dependencies         β”‚
   β”‚ β€’ Create .aws-sam/build/       β”‚
   β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

3. Test Locally
   $ sam local invoke
   $ sam local start-api
   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
   β”‚ β€’ Run Lambda locally           β”‚
   β”‚ β€’ Test API Gateway locally     β”‚
   β”‚ β€’ No AWS charges! βœ…           β”‚
   β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

4. Package (Optional - for CloudFormation)
   $ sam package \
       --s3-bucket my-bucket \
       --output-template-file packaged.yaml
   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
   β”‚ β€’ Upload code to S3            β”‚
   β”‚ β€’ Generate deployment template β”‚
   β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

5. Deploy
   $ sam deploy --guided
   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
   β”‚ β€’ Create CloudFormation stack  β”‚
   β”‚ β€’ Deploy to AWS                β”‚
   β”‚ β€’ Interactive prompts          β”‚
   β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

6. Fast Development (sync)
   $ sam sync --watch
   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
   β”‚ β€’ Direct sync to AWS           β”‚
   β”‚ β€’ Skip CloudFormation          β”‚
   β”‚ β€’ Faster iterations ⚑         β”‚
   β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

7. Debug
   $ sam logs --tail
   └─ Fetch CloudWatch logs

πŸ”„ Step Functions

State Types

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚            Step Functions State Types                     β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                                           β”‚
β”‚  Task State (Execute work)                               β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”‚
β”‚  β”‚ "ProcessOrder": {                           β”‚         β”‚
β”‚  β”‚   "Type": "Task",                           β”‚         β”‚
β”‚  β”‚   "Resource": "arn:aws:lambda:..."          β”‚         β”‚
β”‚  β”‚ }                                           β”‚         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β”‚
β”‚                                                           β”‚
β”‚  Choice State (Branch logic)                             β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”‚
β”‚  β”‚ "IsApproved": {                             β”‚         β”‚
β”‚  β”‚   "Type": "Choice",                         β”‚         β”‚
β”‚  β”‚   "Choices": [                              β”‚         β”‚
β”‚  β”‚     {"Variable": "$.status",                β”‚         β”‚
β”‚  β”‚      "StringEquals": "approved",            β”‚         β”‚
β”‚  β”‚      "Next": "ProcessPayment"}              β”‚         β”‚
β”‚  β”‚   ]                                         β”‚         β”‚
β”‚  β”‚ }                                           β”‚         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β”‚
β”‚                                                           β”‚
β”‚  Parallel State (Concurrent execution)                   β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”‚
β”‚  β”‚ "ParallelProcessing": {                     β”‚         β”‚
β”‚  β”‚   "Type": "Parallel",                       β”‚         β”‚
β”‚  β”‚   "Branches": [                             β”‚         β”‚
β”‚  β”‚     {"StartAt": "Task1"},                   β”‚         β”‚
β”‚  β”‚     {"StartAt": "Task2"}                    β”‚         β”‚
β”‚  β”‚   ]                                         β”‚         β”‚
β”‚  β”‚ }                                           β”‚         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β”‚
β”‚                                                           β”‚
β”‚  Wait State (Delay)                                      β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”‚
β”‚  β”‚ "WaitForApproval": {                        β”‚         β”‚
β”‚  β”‚   "Type": "Wait",                           β”‚         β”‚
β”‚  β”‚   "Seconds": 300                            β”‚         β”‚
β”‚  β”‚ }                                           β”‚         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β”‚
β”‚                                                           β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Step Functions Wait for Callback Pattern

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚      Step Functions waitForTaskToken Pattern              β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Step Functions Workflow
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚ "ProcessOrder": {                    β”‚
β”‚   "Type": "Task",                   β”‚
β”‚   "Resource": "arn:aws:sqs:...      β”‚
β”‚                .waitForTaskToken",  β”‚ ← Note suffix
β”‚   "Parameters": {                   β”‚
β”‚     "QueueUrl": "...",              β”‚
β”‚     "MessageBody": {                β”‚
β”‚       "orderId": "123",             β”‚
β”‚       "token.$": "$$.Task.Token" ←──── Generate token
β”‚     }                               β”‚
β”‚   }                                 β”‚
β”‚ }                                   β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
               β”‚
               β”‚ 1. Send message with token
               β–Ό
          β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”
          β”‚   SQS   β”‚
          β”‚  Queue  β”‚
          β””β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”˜
               β”‚
               β”‚ 2. Worker processes
               β–Ό
        β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
        β”‚   Worker    β”‚
        β”‚  (Lambda)   β”‚
        β””β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”˜
               β”‚
               β”‚ 3. Call SendTaskSuccess/Failure
               β–Ό
        β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
        β”‚ Step Functions  β”‚
        β”‚ Resumes! βœ…     β”‚
        β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Benefits:
βœ… No polling cost (paused workflow)
βœ… Wait for external signals (webhooks, manual approval)
βœ… Long-running processes (hours/days)

Input/Output Processing

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚     Step Functions Input/Output Processing                β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Input: { "orderId": "123", "amount": 100 }
   β”‚
   β”‚ InputPath: "$.orderId"
   β–Ό
Input to Task: "123"
   β”‚
   β”‚ [Task Execution]
   β–Ό
Task Result: { "status": "success", "transactionId": "abc" }
   β”‚
   β”‚ ResultPath: "$.transaction"
   β–Ό
Combined: {
  "orderId": "123",
  "amount": 100,
  "transaction": {
    "status": "success",
    "transactionId": "abc"
  }
}
   β”‚
   β”‚ OutputPath: "$.transaction"
   β–Ό
Final Output: { "status": "success", "transactionId": "abc" }

Summary:
β€’ InputPath: Filter input
β€’ Parameters: Transform input
β€’ ResultPath: Merge result with original input βœ…
β€’ OutputPath: Filter final output

πŸ’Ύ ElastiCache

Redis vs Memcached

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚          ElastiCache: Redis vs Memcached                  β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                                           β”‚
β”‚  Redis ⭐ (Feature-Rich)                                  β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”‚
β”‚  β”‚ βœ… Data Types: Strings, Lists, Sets, Hashesβ”‚         β”‚
β”‚  β”‚ βœ… Persistence (AOF, RDB)                   β”‚         β”‚
β”‚  β”‚ βœ… Replication (Primary/Replica)            β”‚         β”‚
β”‚  β”‚ βœ… Multi-AZ with automatic failover         β”‚         β”‚
β”‚  β”‚ βœ… Backup & Restore                         β”‚         β”‚
β”‚  β”‚ βœ… Pub/Sub messaging                        β”‚         β”‚
β”‚  β”‚ βœ… Transactions                             β”‚         β”‚
β”‚  β”‚ βœ… Sorted Sets (leaderboards)               β”‚         β”‚
β”‚  β”‚                                             β”‚         β”‚
β”‚  β”‚ Use Cases:                                  β”‚         β”‚
β”‚  β”‚ β€’ Session store                             β”‚         β”‚
β”‚  β”‚ β€’ Leaderboards                              β”‚         β”‚
β”‚  β”‚ β€’ Real-time analytics                       β”‚         β”‚
β”‚  β”‚ β€’ Message queues                            β”‚         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β”‚
β”‚                                                           β”‚
β”‚  Memcached (Simple, Multi-threaded)                      β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”‚
β”‚  β”‚ βœ… Simple key-value store                   β”‚         β”‚
β”‚  β”‚ βœ… Multi-threaded                           β”‚         β”‚
β”‚  β”‚ βœ… Horizontal scaling (sharding)            β”‚         β”‚
β”‚  β”‚ ❌ No persistence                           β”‚         β”‚
β”‚  β”‚ ❌ No replication                           β”‚         β”‚
β”‚  β”‚ ❌ No backup                                β”‚         β”‚
β”‚  β”‚ ❌ Only strings                             β”‚         β”‚
β”‚  β”‚                                             β”‚         β”‚
β”‚  β”‚ Use Cases:                                  β”‚         β”‚
β”‚  β”‚ β€’ Simple caching                            β”‚         β”‚
β”‚  β”‚ β€’ Offload database reads                    β”‚         β”‚
β”‚  β”‚ β€’ Temporary data                            β”‚         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β”‚
β”‚                                                           β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Caching Strategies

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚            ElastiCache Caching Strategies                 β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

1. LAZY LOADING (Cache-Aside)
   App                Cache              Database
   β”‚                  β”‚                  β”‚
   β”‚ 1. Read          β”‚                  β”‚
   β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€>β”‚                  β”‚
   β”‚                  β”‚ Cache Miss ❌     β”‚
   β”‚<──────────────────                  β”‚
   β”‚                  β”‚                  β”‚
   β”‚ 2. Query DB      β”‚                  β”‚
   β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€>β”‚
   β”‚                  β”‚                  β”‚
   β”‚ 3. Data          β”‚                  β”‚
   β”‚<───────────────────────────────────────
   β”‚                  β”‚                  β”‚
   β”‚ 4. Write to cacheβ”‚                  β”‚
   β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€>β”‚                  β”‚
   β”‚                  β”‚                  β”‚
   
   πŸ‘ Pros: Only cache used data
   πŸ‘Ž Cons: Cache miss penalty, stale data

2. WRITE-THROUGH
   App                Cache              Database
   β”‚                  β”‚                  β”‚
   β”‚ 1. Write         β”‚                  β”‚
   β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€>β”‚                  β”‚
   β”‚                  β”‚                  β”‚
   β”‚ 2. Update cache  β”‚                  β”‚
   β”‚                  β”‚ 3. Write to DB   β”‚
   β”‚                  β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€>β”‚
   β”‚                  β”‚                  β”‚
   β”‚ 4. Confirm       β”‚                  β”‚
   β”‚<──────────────────                  β”‚
   β”‚                  β”‚                  β”‚
   
   πŸ‘ Pros: Always fresh data
   πŸ‘Ž Cons: Unused data cached, write penalty

3. WRITE-BEHIND (Write-Back)
   App                Cache              Database
   β”‚                  β”‚                  β”‚
   β”‚ 1. Write         β”‚                  β”‚
   β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€>β”‚                  β”‚
   β”‚                  β”‚                  β”‚
   β”‚ 2. Immediate OK  β”‚                  β”‚
   β”‚<──────────────────                  β”‚
   β”‚                  β”‚                  β”‚
   β”‚                  β”‚ 3. Async write   β”‚
   β”‚                  β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€>β”‚
   β”‚                  β”‚    (batched)     β”‚
   
   πŸ‘ Pros: Fast writes, reduced DB load
   πŸ‘Ž Cons: Risk of data loss, complexity

πŸ‘€ Cognito

Cognito Architecture

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚            Amazon Cognito Architecture                    β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

USER POOLS (Authentication)
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚ β€’ User directory                      β”‚
β”‚ β€’ Sign-up / Sign-in                  β”‚
β”‚ β€’ MFA                                 β”‚
β”‚ β€’ Password reset                      β”‚
β”‚ β€’ Social login (Google, Facebook)    β”‚
β”‚ β€’ SAML federation                     β”‚
β”‚                                       β”‚
β”‚ Returns: JWT tokens                   β”‚
β”‚ β”œβ”€ ID Token (user identity)          β”‚
β”‚ β”œβ”€ Access Token (API access)         β”‚
β”‚ └─ Refresh Token                      β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
               β”‚
               β”‚ JWT Token
               β–Ό
IDENTITY POOLS (Authorization)
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚ β€’ Exchange JWT β†’ AWS Credentials     β”‚
β”‚ β€’ IAM role mapping                    β”‚
β”‚ β€’ Temporary credentials (STS)        β”‚
β”‚                                       β”‚
β”‚ Returns: AWS credentials              β”‚
β”‚ β”œβ”€ AccessKeyId                        β”‚
β”‚ β”œβ”€ SecretAccessKey                    β”‚
β”‚ └─ SessionToken                       β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
               β”‚
               β”‚ Temp AWS Creds
               β–Ό
          β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”
          β”‚   S3    β”‚
          β”‚DynamoDB β”‚
          β”‚  etc.   β”‚
          β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Flow:
1. User logs in β†’ User Pool β†’ JWT
2. App sends JWT β†’ Identity Pool β†’ AWS credentials
3. App uses credentials β†’ Access AWS resources

Cognito Adaptive Authentication

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚        Cognito Adaptive Authentication (Risk-Based)       β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Sign-In Attempt
     β”‚
     β–Ό
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚ Risk Assessment     β”‚
β”‚ β€’ IP address        β”‚
β”‚ β€’ Device            β”‚
β”‚ β€’ Location          β”‚
β”‚ β€’ User agent        β”‚
β”‚ β€’ Login history     β”‚
β””β”€β”€β”€β”€β”€β”€β”¬β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
       β”‚
       β”œβ”€β”€β”€β”€ Low Risk
       β”‚     └─> Allow login (no MFA)
       β”‚
       β”œβ”€β”€β”€β”€ Medium Risk
       β”‚     └─> Optional MFA or Require MFA
       β”‚
       └──── High Risk
             └─> Require MFA or Block

Configuration:
β€’ Set risk tolerance per risk level
β€’ Automatic threat detection
β€’ Compromised credentials check
β€’ Advanced security features (paid)

🌍 CloudFront

CloudFront Distribution Architecture

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚           CloudFront Content Delivery                     β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

                Global Users
                     β”‚
        ┏━━━━━━━━━━━━┻━━━━━━━━━━━━┓
        β–Ό            β–Ό             β–Ό
   β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”    β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”
   β”‚ Edge   β”‚  β”‚ Edge   β”‚    β”‚ Edge   β”‚
   β”‚ Tokyo  β”‚  β”‚ London β”‚    β”‚ N.Virginia
   β””β”€β”€β”€β”€β”¬β”€β”€β”€β”˜  β””β”€β”€β”€β”€β”¬β”€β”€β”€β”˜    β””β”€β”€β”€β”€β”¬β”€β”€β”€β”˜
        β”‚           β”‚             β”‚
        β”‚      Cache Miss?        β”‚
        β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”Όβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
                    β”‚
                    β–Ό
            β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
            β”‚ Origin Server β”‚
            β”‚ β€’ S3 Bucket   β”‚
            β”‚ β€’ ALB         β”‚
            β”‚ β€’ Custom      β”‚
            β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Benefits:
βœ… Low latency (content served from edge)
βœ… Reduced origin load
βœ… DDoS protection
βœ… HTTPS encryption

CloudFront SSL/TLS

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚      CloudFront SSL/TLS Configuration                     β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Viewer β†’ CloudFront β†’ Origin

Viewer Protocol Policy:
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚ β€’ HTTP and HTTPS (allow both)          β”‚
β”‚ β€’ Redirect HTTP to HTTPS ⭐             β”‚
β”‚ β€’ HTTPS Only                            β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Origin Protocol Policy:
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚ β€’ HTTP Only                             β”‚
β”‚ β€’ HTTPS Only                            β”‚
β”‚ β€’ Match Viewer                          β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Recommended: Redirect HTTP to HTTPS (viewer)
             + HTTPS Only (origin)

πŸ”„ Kinesis Data Streams

Kinesis Architecture

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚            Kinesis Data Streams Flow                      β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Producers                Kinesis Stream              Consumers
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”              β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”           β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚  IoT    │─────────────>β”‚   Shard 1    │──────────>β”‚ Lambda  β”‚
β”‚ Devices β”‚              β”‚  1MB/s write β”‚           β”‚         β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜              β”‚  2MB/s read  β”‚           β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
                         β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”              β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”           β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚  App    │─────────────>β”‚   Shard 2    │──────────>β”‚   EC2   β”‚
β”‚ Servers β”‚              β”‚              β”‚           β”‚  KCL    β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜              β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜           β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜
                         β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”           β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”              β”‚   Shard 3    │──────────>β”‚ Kinesis β”‚
β”‚  Logs   │─────────────>β”‚              β”‚           β”‚Analyticsβ”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜              β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜           β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Partition Key β†’ Determines shard assignment
Sequence Number β†’ Unique ID per record (ordering)

Concurrency: 1 Lambda execution per shard
Ordering: Use PutRecord with SequenceNumberForOrdering

πŸ” Secrets Manager & SSM Parameter Store

Comparison

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚       Secrets Manager vs SSM Parameter Store              β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚                                                           β”‚
β”‚  AWS Secrets Manager ⭐                                   β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”‚
β”‚  β”‚ βœ… Automatic rotation                       β”‚         β”‚
β”‚  β”‚ βœ… Native RDS/Redshift integration          β”‚         β”‚
β”‚  β”‚ βœ… Cross-account access                     β”‚         β”‚
β”‚  β”‚ βœ… Versioning                               β”‚         β”‚
β”‚  β”‚ βœ… KMS encryption                           β”‚         β”‚
β”‚  β”‚ πŸ’° Cost: $0.40/secret/month                β”‚         β”‚
β”‚  β”‚                                             β”‚         β”‚
β”‚  β”‚ Use: Database credentials, API keys         β”‚         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β”‚
β”‚                                                           β”‚
β”‚  SSM Parameter Store                                     β”‚
β”‚  β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”         β”‚
β”‚  β”‚ βœ… Free (Standard tier)                     β”‚         β”‚
β”‚  β”‚ βœ… Parameter hierarchies (/prod/db/url)    β”‚         β”‚
β”‚  β”‚ βœ… KMS encryption (SecureString)            β”‚         β”‚
β”‚  β”‚ ❌ No automatic rotation                    β”‚         β”‚
β”‚  β”‚                                             β”‚         β”‚
β”‚  β”‚ Standard Tier:                              β”‚         β”‚
β”‚  β”‚ β€’ 10,000 params                             β”‚         β”‚
β”‚  β”‚ β€’ 4 KB max size                             β”‚         β”‚
β”‚  β”‚ β€’ Free                                      β”‚         β”‚
β”‚  β”‚                                             β”‚         β”‚
β”‚  β”‚ Advanced Tier:                              β”‚         β”‚
β”‚  β”‚ β€’ 100,000 params                            β”‚         β”‚
β”‚  β”‚ β€’ 8 KB max size                             β”‚         β”‚
β”‚  β”‚ β€’ Parameter policies                        β”‚         β”‚
β”‚  β”‚ β€’ $0.05/param/month                         β”‚         β”‚
β”‚  β”‚                                             β”‚         β”‚
β”‚  β”‚ Use: Configuration, non-sensitive data      β”‚         β”‚
β”‚  β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜         β”‚
β”‚                                                           β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

🎯 Exam Tips & Common Patterns

Service Selection Patterns

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚            Common Exam Question Patterns                  β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

Authentication Needed?
β”œβ”€ Social Login (Google, FB) β†’ Cognito User Pool
β”œβ”€ Enterprise SSO β†’ Cognito + SAML
└─ API Authentication β†’ API Gateway Lambda Authorizer

Access AWS Resources?
β”œβ”€ From mobile app β†’ Cognito Identity Pool
β”œβ”€ From Lambda β†’ Execution Role
└─ From EC2 β†’ Instance Profile

Decouple Services?
β”œβ”€ Pub/Sub (multiple subscribers) β†’ SNS
β”œβ”€ Queue (single consumer) β†’ SQS
└─ Stream (ordered, real-time) β†’ Kinesis

Store Configuration?
β”œβ”€ Secrets (rotation needed) β†’ Secrets Manager
β”œβ”€ Simple config β†’ SSM Parameter Store
└─ Application config β†’ AppConfig

Cache Layer?
β”œβ”€ Complex data types β†’ ElastiCache Redis
β”œβ”€ Simple key-value β†’ ElastiCache Memcached
└─ API responses β†’ API Gateway caching

Monitoring?
β”œβ”€ Application logs β†’ CloudWatch Logs
β”œβ”€ Custom metrics β†’ CloudWatch EMF
β”œβ”€ Distributed tracing β†’ X-Ray
└─ Infrastructure metrics β†’ CloudWatch

Deployment Strategy?
β”œβ”€ Zero downtime β†’ Blue/Green
β”œβ”€ Gradual rollout β†’ Canary/Linear
└─ Fast, accept downtime β†’ All-at-once

Serverless?
β”œβ”€ Compute β†’ Lambda
β”œβ”€ API β†’ API Gateway
β”œβ”€ Database β†’ DynamoDB
└─ Orchestration β†’ Step Functions

Key Exam Keywords

β”Œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”
β”‚              Keyword β†’ Service Mapping                    β”‚
β”œβ”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€
β”‚ "Serverless" β†’ Lambda, DynamoDB, API Gateway, Step Fns   β”‚
β”‚ "Decouple" β†’ SQS, SNS                                    β”‚
β”‚ "Cache" β†’ ElastiCache, API Gateway caching              β”‚
β”‚ "Ordered messages" β†’ SQS FIFO, Kinesis                   β”‚
β”‚ "Real-time" β†’ Kinesis, Lambda, WebSockets               β”‚
β”‚ "Audit logs" β†’ CloudTrail                               β”‚
β”‚ "Distributed tracing" β†’ X-Ray                            β”‚
β”‚ "Secrets rotation" β†’ Secrets Manager                     β”‚
β”‚ "Cross-account" β†’ IAM roles, STS AssumeRole              β”‚
β”‚ "Least privilege" β†’ Separate IAM roles                   β”‚
β”‚ "Cost-effective" β†’ Free tier, managed services           β”‚
β”‚ "High availability" β†’ Multi-AZ, Auto Scaling             β”‚
β”‚ "Disaster recovery" β†’ Cross-region replication           β”‚
β””β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”€β”˜

πŸ“š Quick Reference Tables

DynamoDB Capacity Units

OperationCalculationExample
RCU (Eventually Consistent)Item size (KB) / 48 KB item = 2 RCU
RCU (Strongly Consistent)Item size (KB) / 4 Γ— 28 KB item = 4 RCU
WCUItem size (KB) / 13 KB item = 3 WCU

Lambda Limits

LimitValue
Memory128 MB - 10 GB
Timeout15 minutes max
Deployment package50 MB (zipped), 250 MB (unzipped)
/tmp storage512 MB - 10 GB
Concurrent executions1,000 per account (soft limit)
Environment variables4 KB total

API Gateway Limits

LimitValue
Timeout29 seconds (all integrations)
Payload size10 MB
Cache TTL0 - 3600 seconds
Throttle (default)10,000 RPS, 5,000 burst

SQS Limits

FeatureStandardFIFO
ThroughputUnlimited300 TPS (3,000 with batching)
Message retention1 min - 14 days (default 4 days)Same
Message size256 KB256 KB
Visibility timeout0 - 12 hours (default 30s)Same
Long polling0 - 20 secondsSame

πŸ”₯ Last-Minute Review Checklist

Must-Know Concepts

Lambda

  • Invocation types: RequestResponse, Event, DryRun
  • Event source mapping (Kinesis, DynamoDB, SQS)
  • Concurrency limits (1000 total, 900 max reserved)
  • Environment variables (encrypted with KMS)
  • Execution role vs Task role
  • Lambda@Edge for CloudFront

API Gateway

  • Integration types: HTTP_PROXY, AWS_PROXY (Lambda)
  • Authorization: IAM, Lambda Authorizer, Cognito, API Keys
  • Stages and stage variables
  • Caching (per stage, TTL 0-3600s)
  • 29-second timeout limit

DynamoDB

  • GSI vs LSI (creation time, consistency)
  • Hot partition solutions (add random suffix)
  • Streams: OLD_IMAGE, NEW_IMAGE, KEYS_ONLY
  • Query vs Scan (efficiency)
  • Optimistic locking (version attribute)
  • BatchGetItem (100 items), BatchWriteItem (25 items)

SQS

  • Standard vs FIFO queues
  • Visibility timeout vs Message retention
  • Long polling (WaitTimeSeconds = 1-20)
  • Extended Client Library (256 KB - 2 GB via S3)

CloudWatch

  • Standard vs High-resolution metrics
  • Alarm configuration (Period, Evaluation Periods, Datapoints)
  • EMF (Embedded Metric Format) for custom metrics
  • Metric filters (not retroactive)

X-Ray

  • Trace β†’ Segment β†’ Subsegment hierarchy
  • Annotations (searchable) vs Metadata (not searchable)
  • Daemon required for EC2/ECS, not Lambda
  • Namespaces: aws, remote, local

CodeDeploy

  • Lifecycle hooks (EC2 vs Lambda vs ECS)
  • Canary vs Linear deployment
  • In-place vs Blue/Green
  • AppSpec file requirements

Elastic Beanstalk

  • Deployment strategies (All-at-once β†’ Immutable β†’ Blue/Green)
  • env.yaml vs .ebextensions/*.config
  • Worker tier (SQS + daemon)

Cognito

  • User Pools (authentication) vs Identity Pools (authorization)
  • JWT tokens β†’ AWS credentials flow
  • Adaptive authentication (risk-based MFA)

IAM & Security

  • STS APIs: GetSessionToken, AssumeRole, AssumeRoleWithWebIdentity
  • Cross-account access pattern
  • KMS: Symmetric vs Asymmetric keys
  • S3 encryption: SSE-S3, SSE-KMS, SSE-C

πŸŽ“ Final Tips

During the Exam

  1. Read carefully - One word can change the answer (e.g., β€œimmediately” vs β€œeventually”)
  2. Eliminate wrong answers - Usually 2 are obviously wrong
  3. Look for keywords - β€œserverless”, β€œdecouple”, β€œcost-effective”
  4. Don’t overthink - Choose the most AWS-native solution
  5. Time management - 130 minutes for 65 questions (~2 min/question)

Common Traps

  • ❌ Overengineering - AWS exams prefer simple, managed solutions
  • ❌ Self-hosted solutions - When AWS has a managed service, use it
  • ❌ Complex architectures - Simpler is usually better
  • ❌ Missing keywords - β€œreal-time”, β€œordered”, β€œstrongly consistent”

AWS Best Practices Always Win

  • βœ… Managed services over self-hosted
  • βœ… Serverless over servers (when possible)
  • βœ… Least privilege IAM policies
  • βœ… Multi-AZ for high availability
  • βœ… Caching to reduce latency/cost
  • βœ… Monitoring and logging enabled

Good luck on your AWS DVA-C02 exam! πŸš€

Remember: This is a summary based on exam focus areas. Always refer to official AWS documentation for detailed information.