Beginner
10h
Updated 2 months ago
WHAT YOU'LL LEARN
Show more
Content
2.
Introduction
2 Lessons
3.
Abstractions
4 Lessons
4.
Non-functional System Characteristics
6 Lessons
5.
Back-of-the-envelope Calculations
2 Lessons
6.
Building Blocks
1 Lessons
7.
Domain Name System
2 Lessons
8.
Load Balancers
3 Lessons
9.
Databases
5 Lessons
10.
Key-value Store
5 Lessons
11.
Content Delivery Network (CDN)
7 Lessons
12.
Sequencer
3 Lessons
13.
Distributed Monitoring
3 Lessons
14.
Monitor Server-side Errors
3 Lessons
15.
Monitor Client-side Errors
2 Lessons
16.
Distributed Cache
6 Lessons
17.
Distributed Messaging Queue
7 Lessons
18.
Pub-sub
3 Lessons
19.
Rate Limiter
5 Lessons
20.
Blob Store
6 Lessons
21.
Distributed Search
6 Lessons
22.
Distributed Logging
3 Lessons
23.
Distributed Task Scheduler
5 Lessons
24.
Sharded Counters
4 Lessons
25.
Concluding the Building Blocks Discussion
4 Lessons
26.
Design YouTube
6 Lessons
27.
Design Quora
5 Lessons
28.
Design Google Maps
6 Lessons
29.
Design a Proximity Service / Yelp
5 Lessons
30.
Design Uber
7 Lessons
31.
Design Twitter
6 Lessons
32.
Design Newsfeed System
4 Lessons
33.
Design Instagram
5 Lessons
34.
Design a URL Shortening Service / TinyURL
6 Lessons
35.
Design a Web Crawler
5 Lessons
36.
Design WhatsApp
6 Lessons
37.
Design Typeahead Suggestion
7 Lessons
38.
Design a Collaborative Document Editing Service / Google Docs
5 Lessons
39.
Spectacular Failures
4 Lessons
40.
Concluding Remarks
1 Lessons
Trusted by 2.7 million developers working at companies
Anthony Walker
@_webarchitect_
Evan Dunbar
ML Engineer
Software Developer
Carlos Matias La Borde
Souvik Kundu
Front-end Developer
Vinay Krishnaiah
Software Developer
See how Educative uses AI to make your learning more immersive than ever before.
AI Prompt
Code Feedback
Explain with AI
AI Code Mentor
Free Resources
Frequently Asked Questions
What’s the best way to architect a scalable file-storage system for large creative assets?
How can an online image-editing platform be designed to support high-resolution, multi-layer files?
What would an event-driven analytics system look like for tracking creative-tool usage in real time?
How can you scale a content-delivery system globally to serve design files with minimal latency?
What’s an effective approach to implementing API rate-limiting for different customer tiers?
How could a real-time collaboration tool like Adobe XD be built to handle concurrent editing sessions?
What’s the right way to design a search engine for Adobe’s asset libraries that handles both text and visual queries?
How should a scalable video-encoding pipeline be structured for thousands of simultaneous Premiere Pro exports?
What factors go into building a responsive typeahead suggestion box for a creative-asset search tool?
How can type-ahead search be designed to combine recent searches, entities, and quick actions in one interface?