...
/Requirements of the Typeahead Suggestion System’s Design
Requirements of the Typeahead Suggestion System’s Design
Learn about the requirements and resource estimations for the design of the typeahead suggestion system.
We'll cover the following...
Requirements
In this lesson, we look into the requirements and estimated resources that are necessary for the design of the typeahead suggestion system. Our proposed design should meet the following requirements.
Functional requirements
The system should suggest top 
Non-functional requirements
- Low latency: The system should show all the suggested queries in real time after a user types. The latency shouldn’t exceed 200 ms. A study suggests that the average time between two keystrokes is 160 milliseconds. So, our time budget of suggestions should be greater than 160 ms to give a real-time response. This is because if a user is typing fast, they already know what to search and might not need suggestions. At the same time, our system response should be greater than 160 ms. However, it should not be too high because in that case, a suggestion might be stale and less useful. 
- Fault tolerance: The system should be reliable enough to provide suggestions despite the failure of one or more of its components. 
- Scalability: The system should support the ever-increasing number of users over time. 
Resource estimation
As was stated earlier, the typeahead feature is used to enhance the user experience while typing a query. We need to design a system that works on a scale that’s similar to Google Search. Google receives more than 3.5 billion searches every day. Designing such an enormous system is a challenging task that requires different resources. Let’s estimate the storage and bandwidth requirements for the proposed system.
Storage estimation
Assuming that out of the 3.5 billion queries per day, two billion queries are unique and need to be stored. Let’s also assume that each query consists of 15 characters on average, and each character ...