Requirements
Functional Requirements:
- Create a short URL for a given long URL.
- Return the long URL associated with a given short URL.
Non-Functional Requirements:
- Low latency
- High consistency
- Scalable to 1 lakh req / s
API Design
GET /urls/?url=
Status code: 301 redirect
{
"redirected_url":
}
POST
/urls/
{
"url": "long format url",
"short_code":
"expiry":
}
return {
"url":
}
High-Level Design
URL can be shotened using base 62 encoding
We can have bloom filter to check if the url exists or not for the given short code while creation
For expiry of urls, we can have postgresql extension installed to mark field as inactive when its ttl is crossed
Detailed Component Design
Deep dive into 2-3 key components. Explain how they work, how they scale, discuss tradeoffs, capacity, and any relevant algorithms or data structures.