Add more articles: - Horizontal vs Vertical Scaling - API Design - Synchronous vs. asynchronous communications
9.2 KiB
9.2 KiB
Awesome System Design Resources
This repository contains resources to learn System Design concepts and prepare for interviews all using free resources.
System Design Fundamentals
- Horizontal vs Vertical Scaling
- 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
- API Design
- Strong vs Eventual Consistency
- Consistency Patterns
- Synchronous vs. asynchronous communications
- 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
- API Gateway
- Serverless Architecture
- Service Discovery
- Disaster Recovery
- Distributed Locking
- Distributed Tracing
- Checksum
System Design Interview Template
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