filmov
tv
System Design: TINDER as a microservice architecture
Показать описание
Looking to ace your next interview? Try this System Design video course! 🔥
We design the system architecture of Tinder. Designing these apps starts with clarifying the system requirements. In an interview, Tinder has multiple requirements.
When designing the system, we will be drawing logical components and defining their interactions with other services based on the microservice architecture. We assume that any internal details can be handled with our prior knowledge of system design concepts. This includes load balancing, message queues, databases, etc...
The Tinder system has four requirements: storing profiles, recommendations, noting matches and chatting with matches. Storing profiles is trivial except for the image storage, where we argue on BLOB vs File storage. The distributed file architecture seems best when storing images.
Direct Messaging or chatting with matches can be done using the XMPP protocol, which uses web sockets to have peer-to-peer communications between client and server. Each connection is built over TCP, ensuring that the connection is maintained. The session microservice can send messages to the receiver based on connection to user mappings.
Our system is decoupled as much as possible. We try to maintain accept and reject information on the client. On swiping left or right, the client can note the action and avoid showing the same user again, perhaps using bloom filters.
The server has a validation engine called the matcher microservice, which notes matches and allows or disallows chat between two users.
The final requirement of recommendations needs city-wise partitioning of the user data. This is achieved using NoSQL databases like Cassandra or Amazon Dynamo. The other option is to use relational databases with horizontal partitioning. The concept is now referred to as sharding.
If you have any doubts, suggestions, or feedback, I love to hear them below. This system is by no means complete, but it is enough for an hour-long interview.
Disclaimer: The video does not contain or suggest the internal implementation of Tinder. The system we design is purely imaginary and has no links with the real app. I am sure the engineers at Tinder have done better than this!
00:00 Prerequisites
00:40 Picking features
05:50 Storing images
12:30 System Design
18:22 Direct messaging for chat
23:45 Matching algorithm
27:16 Recommendation Engine
34:40 Final pointers
CDN -
Consistent Hashing -
System Design Playlist -
You can follow me on:
#SystemDesign #SoftwareInterview #Tinder
We design the system architecture of Tinder. Designing these apps starts with clarifying the system requirements. In an interview, Tinder has multiple requirements.
When designing the system, we will be drawing logical components and defining their interactions with other services based on the microservice architecture. We assume that any internal details can be handled with our prior knowledge of system design concepts. This includes load balancing, message queues, databases, etc...
The Tinder system has four requirements: storing profiles, recommendations, noting matches and chatting with matches. Storing profiles is trivial except for the image storage, where we argue on BLOB vs File storage. The distributed file architecture seems best when storing images.
Direct Messaging or chatting with matches can be done using the XMPP protocol, which uses web sockets to have peer-to-peer communications between client and server. Each connection is built over TCP, ensuring that the connection is maintained. The session microservice can send messages to the receiver based on connection to user mappings.
Our system is decoupled as much as possible. We try to maintain accept and reject information on the client. On swiping left or right, the client can note the action and avoid showing the same user again, perhaps using bloom filters.
The server has a validation engine called the matcher microservice, which notes matches and allows or disallows chat between two users.
The final requirement of recommendations needs city-wise partitioning of the user data. This is achieved using NoSQL databases like Cassandra or Amazon Dynamo. The other option is to use relational databases with horizontal partitioning. The concept is now referred to as sharding.
If you have any doubts, suggestions, or feedback, I love to hear them below. This system is by no means complete, but it is enough for an hour-long interview.
Disclaimer: The video does not contain or suggest the internal implementation of Tinder. The system we design is purely imaginary and has no links with the real app. I am sure the engineers at Tinder have done better than this!
00:00 Prerequisites
00:40 Picking features
05:50 Storing images
12:30 System Design
18:22 Direct messaging for chat
23:45 Matching algorithm
27:16 Recommendation Engine
34:40 Final pointers
CDN -
Consistent Hashing -
System Design Playlist -
You can follow me on:
#SystemDesign #SoftwareInterview #Tinder
Комментарии