System Design: Twitter (5+ Approaches)

  Рет қаралды 6,504

System Design Fight Club

System Design Fight Club

Күн бұрын

Пікірлер: 12
@SDFC
@SDFC Жыл бұрын
NOTES & FILES: - excalidraw file: excalidraw.com/#json=wOCs42zY3ba3_UWsCA1W2,-ihYDBv-ek0brC1Ix7dWWw - screenshots of the excalidraw file: imgur.com/a/iARP5so - text file: pastebin.com/m9DiQwNg
@totsubo2000
@totsubo2000 2 ай бұрын
Great explanation of the fan-out approach! One challenge I see with this solution is when a post has thousands of followers (not quite a celebrity's reach, but still substantial). The task worker would need to make thousands of individual database calls, which could keep it busy for an extended period. Additionally, any failure during this process might lead to missed timeline updates. If the worker restarts from Kafka, it would need to redo all those DB writes, as it wouldn't have a record of which ones succeeded before the crash. Is this a real issue, and if so how could it be managed effectively?
@panhejia
@panhejia Жыл бұрын
Really neet content as always. i think the last cold start question is more about how to generate a user's full timeline when they first join Twitter. Like what would twitter do if the newcomer have not followed anyone yet... They can't be showing a blank page, right? I was thinking maybe having the newcomer select a few topics/categories that they are interested in, and from the TopK analysis of all the tweets, just show them some top clicked tweets. Or maybe straightup recommend some celebrities when the newcomer joins twitter. After all, fetching celebrity is a poll based mechanism.
@slavone666
@slavone666 8 ай бұрын
Starts at 13:06
@panhejia
@panhejia Жыл бұрын
One more question, if celebrity 1 follows celebrity 2, how to build celebrity 1's timeline? poll based method as everyone else? Or maybe build some sort of smaller social circle within Twitter just for the celebrities?
@LolLol007
@LolLol007 Жыл бұрын
Thank you for your work
@rohit-ld6fc
@rohit-ld6fc 7 ай бұрын
why the followerDB is ready heavy? it will have the same number of read request as tweets get created. only difference is that the processing is going to take time for those read queries. that does not mean the read calls are going to be huge.
@swaroopas5207
@swaroopas5207 4 ай бұрын
Yes, you're right. However, I believe query patterns can also help identify the best database choice, not just read/write traffic.
@armenchik_dzhan
@armenchik_dzhan 10 күн бұрын
Are you sure that DB trigger is atomic? What happens if you publish your tweet to kafka, but after it was published the transaction fails?
@Tarigvenus511
@Tarigvenus511 Жыл бұрын
Very nice ❤
@handle-handler
@handle-handler Жыл бұрын
Thankyou❤
@user-cg4yi7bh5e
@user-cg4yi7bh5e Жыл бұрын
Thank you
System Design: Nested Comments
1:18:32
System Design Fight Club
Рет қаралды 7 М.
Google Interview Question | System Design: Hypersonic Missile
1:16:40
System Design Fight Club
Рет қаралды 1,8 М.
КОНЦЕРТЫ:  2 сезон | 1 выпуск | Камызяки
46:36
ТНТ Смотри еще!
Рет қаралды 3,7 МЛН
Absolutely Everything That I Know About Database Indexes
55:43
System Design Fight Club
Рет қаралды 17 М.
Uber Interview Question | System Design: OTP with Cache (5+ Approaches)
1:25:54
System Design Fight Club
Рет қаралды 5 М.
Yelp system design | amazon interview question Yelp software architecture
57:31
Tech Dummies Narendra L
Рет қаралды 83 М.
Design Twitter - System Design Interview
26:16
NeetCode
Рет қаралды 546 М.
Keynote: Twitter's search architecture
1:01:02
LuceneSolrRevolution
Рет қаралды 28 М.
System Design Interview: Design Ticketmaster w/ a Ex-Meta Staff Engineer
58:39
Hello Interview - SWE Interview Preparation
Рет қаралды 176 М.