System Design Architecture StackOverflow
2 min readFeb 21, 2022
Stack Overflow is a question-and-answer website for professional and enthusiast programmers. In the previous post, we discussed LLD, in this post we are going to discuss the HLD of StackOverflow.
Functional Requirements
- Post questions, answers, upvotes, and downvotes.
- Follow Users.
- Home Timeline: To show relevant questions to users.
- Search Questions.
Non Functional Requirements
- High Availability
- Low Latency (Real Time)
Estimations:
- Total Users: 20M
- Total Questions: 25M
- Toal Answers: 40M
- Total Votes: 200M
Questions/day: 5K
Answers/day: 7K
Votes/day : 36K
Active Users/day: 5000
Storage Estimations:
Size of each question and answer: 30KB
Votes: 20 Bytes
UserMetaData(like views, time spent, etc.): 10KB
Storage/day: 30KB*(5000+7000) + 20Bytes*(36000) + 10KB*(5000) = 410MB
Database:
Services:
- User App/ Web App: Used to Add/Delete/Modify Questions and answers. Voting questions and answers.
- Question Service: A list of API Servers handles queries related to questions like Add/Modify questions.
- Answer Service.
- Vote Service: For upvote and downvote.
- User Activity Service: Use Pub-Sub model like Kafka and store them in HDFS data store.
- LOG Service: Subscribe to user activities topics and publish messages for notification service also storing all logs in HDFS data store that can be used later for recommending questions to different users, analytics, etc.
- Load Balancer: Behind different API servers that handle different services (Question Service, Answer Service).
- API Gateway: That forwards traffic to different Load balancers (Path-Based API Gateway).
- Home Timeline Service.
- Cache Populator Service: Cron which populate the cache with say top 200 questions per user. Also, we can run this service on demand to fetch more questions say when a user viewed 100 out of 200 questions. It may use some machine learning algorithms to fetch questions. This also uses logs saved by the User Activity Service to populate questions in our cache using some machine learning algorithms or any other recommendation algorithms.
- Search Service (Lets’s discuss this later). For now, I am considering that there is already a search service.
- Notification Service. (Real-Time)
High-Level Architecture:
ThankYou. Please do give suggestions.