Versions Compared
Version | Old Version 9 | New Version 10 |
---|---|---|
Changes made by | ||
Saved on |
Key
- This line was added.
- This line was removed.
- Formatting was changed.
Tip |
---|
The Framework proposed in this space (Alex Xu) is applied to propose a design : Getting started - a framework to propose... |
On this page.
Table of Contents |
---|
Introduction
News feed is the constantly updating list of stories in the middle of the home page. It includes status updates, photos, links, video, etc.
Part 1 - Understand the problem and establish design scope
Accessible via Mobile App or/and Web App ? | Both |
---|---|
Features ? | Publish and See other posts (from other users) |
How is sorted the news feed ? | Reverse chronological order |
How many friends user can have ? | 5000 |
Traffic volume ? | 10 million per day, active users |
Contain images, videos or just text ? | All. |
Part 2 - High-Level design
data:image/s3,"s3://crabby-images/79c61/79c61ba229696008a4460621d36b41b8f7594bdd" alt=""
2 flows :
Feed publishing → user publishes a post, corresponding data is written into cache and DB.
Newsfeed building → news feed is built by aggregating friends’ posts in revers reverse chronological order.
Part 3 - Deep dive design
Flow Feed Publishing
Focus is on Web servers and the fanout service.
data:image/s3,"s3://crabby-images/153f6/153f6b221af71ea27be634bdd15815f68d1c5163" alt=""
Flow Newsfeed Retrieval
Focus is on the CDN and the News Feed Service :
Service fetches complete user and post objects from caches.
News feed is returned in JSON format back to the client for rendering.
data:image/s3,"s3://crabby-images/6e1f6/6e1f65cd2da4b9d4187583254c2abd3f52251f81" alt=""