Awesome System Design Resources
This repository contains resources to learn System Design concepts and prepare for interviews all using free resources.
System Design Fundamentals
- Content Delivery Network (CDN)
- Caching
- Distributed Caching
- Latency vs Throughput
- CAP Theorem
- Load Balancing
- ACID Transactions
- SQL vs NoSQL
- Consistent Hashing
- Database Index
- Rate Limiting
- Microservices Architecture
- Microservices Guidelines
- Strong vs Eventual Consistency
- Consistency Patterns
- REST vs RPC
- Batch Processing vs Stream Processing
- HeartBeat
- Circuit Breaker
- Idempotency
- Database Scaling
- Data Replication
- Data Redundancy
- Database Sharding
- Fault Tolerance
- Failover
- Proxy Server
- Domain Name System (DNS)
- Message Queues
- WebSockets
- Bloom Filters
- Consensus Algorithms
- Gossip Protocol
- Bloom Filters
- API Gateway
- Serverless Architecture
- Service Discovery
- Disaster Recovery
- Distributed Locking
- Distributed Tracing
- Checksum
System Design Interview Problems
Easy
- Design Leaderboard
- Design URL Shortener like TinyURL
- Design Text Storage Service like Pastebin
- Design Content Delivery Network (CDN)
- Design Parking Garage
- Design Vending Machine
- Design Distributed Key-Value Store
- Design Distributed Cache
- Design Distributed Job Scheduler
- Design Authentication System
- Design Unified Payments Interface (UPI)
Medium
- Design Instagram
- Design Tinder
- Design WhatsApp
- Design Facebook
- Design Twitter
- Design Reddit
- Design Netflix
- Design Youtube
- Design Google Search
- Design E-commerce Store like Amazon
- Design Spotify
- Design TikTok
- Design Shopify
- Design Airbnb
- Design Autocomplete for Search Engines
- Design Rate Limiter
- Design Distributed Message Queue like Kafka
- Design Flight Booking System
- Design Online Code Editor
- Design Stock Exchange System
- Design an Analytics Platform (Metrics & Logging)
- Design Notification Service
- Design Payment System
- Design a Digital Wallet
Hard
- Design Slack
- Design Live Comments
- Design Distributed Counter
- Design Location Based Service like Yelp
- Design Uber
- Design Food Delivery App like Doordash
- Design Google Docs
- Design Google Maps
- Design Zoom
- Design File Sharing System like Dropbox
- Design Ticket Booking System like BookMyShow
- Design Distributed Web Crawler
- Design Code Deployment System
- Design Distributed Cloud Storage like S3
- Design Distributed Locking Service
Must-Read Engineering Articles
- How Discord stores trillions of messages
- Building In-Video Search
- How Canva scaled Media uploads from Zero to 50 Million per Day
- How Airbnb avoids double payments in a Distributed Payments System
- Stripeβs payments APIs - The first 10 years
- Real time messaging at Slack