Uber System Design | Ola System Design | System Design Interview Question - Grab, Lyft

Sdílet
Vložit
  • čas přidán 18. 05. 2020
  • This is a solution for System Design Interview Question where you need to design a Cab booking System like Uber/ Ola/ Grab/ Lyft, etc.
    Recommended Videos to watch before this:
    Google Maps System Design: • Google Maps System Des...
    How o select the right Database for a Large Scale System: • Database Design Tips |...
    Summary of this video: www.codekarle.com/system-desi...
    Architecture diagram: github.com/codekarle/system-d...
    Author: / sandeep1904
    If you like this video, please help us grow by sharing this video with your friends on Facebook, connections on LinkedIn and anyone who can benefit from this.
    PS: This is not the real architecture of any such platform. This is my take on how I would answer that problem.
    #codekarle #systemdesign #ubersystemdesign #system #design #interview #amazon #faang #Uber #Ola

Komentáře • 96

  • @puneetapiit
    @puneetapiit Před 3 lety +110

    Bro you are fantastic. So today I had an interview with MSCI (Morgan Stanley) and they asked me about designing around Ola, where they wanted me to show the cabs around a user as soon as he logins to the app. I remembered this video of yours and explained how things work and how the mapping service would divide the city into grids and fetch the information. The interviewer was satisfied and I feel I have cracked the round. All thanks to you \m/

    • @rishav144
      @rishav144 Před rokem +2

      so, u joined Morgan stanley ??

    • @ofuochi
      @ofuochi Před rokem +1

      Did you finally join MSCI?

    • @SuperHARIS14
      @SuperHARIS14 Před 11 měsíci +2

      bro, don't keep us hanging around... share if you were selected?

    • @shauryavardhansingh7917
      @shauryavardhansingh7917 Před 7 měsíci

      he go banned from applying@@rishav144

    • @123asda
      @123asda Před měsícem

      No he did not join morgan stanley..he joined byju’s n then jio..

  • @prashub8707
    @prashub8707 Před rokem +2

    You are an amazing teacher. Why have you stopped making such an amazing videos . Kindly create contents of top quality. You rock

  • @mohitkalra9329
    @mohitkalra9329 Před 4 měsíci +2

    This is the best video for uber system design out there!

  • @sanmeet
    @sanmeet Před rokem +1

    Great video on two main dimensions that makes it easy to follow and appreciate:
    1. Scope of the product is clearly defined
    2. Delivery of content is very crisp and to the point
    Cant stress how many other videos out there have a catchy title like "Design Uber service" that goes all over the place in terms of what it wants to cover and how to delivery the content. This is the best video on Uber System design available on CZcams.

  • @evkumar71
    @evkumar71 Před 2 lety

    I watched a couple of videos on Uber system design and wasn't satisfied and luckily ended up here. Very good explanation focusing on key components. Thanks bro !

  • @abhinav8804
    @abhinav8804 Před rokem +6

    What an amazing explanation to the most complex of things. Teaching is an art, and it does get exemplified by your teaching style.
    Kudos to you man

  • @keerthikanthchowdary2676
    @keerthikanthchowdary2676 Před 2 lety +18

    It would have been great if you had covered how the request for cab is fanned out to multiple drivers and once any one driver accepts the trip, how the request is dropped from all the other drivers. overall content is very good and helpful. Very good effort.

  • @mohitjain5232
    @mohitjain5232 Před 2 lety +2

    Great video! Very cohesive and in-depth. Thanks.

  • @rptok
    @rptok Před 2 lety +9

    All your videos are very good. They are good to think about various requirements, splitting a given problem into multiple services and so on. But I think you haven't been talking about the data model, how it can be represented in a NoSql vs RDBMS vs graph database, and so on. Many interviewers expect that discussions, if not all. Hope you can do that in your future videos. Thanks!

  • @mayanklalaiya9669
    @mayanklalaiya9669 Před 2 lety

    This video is very good. The best thing is that you have provided summary also with clear diagram.
    Thank You very much.

  • @ravig5413
    @ravig5413 Před 11 měsíci

    man, you are real good. seems you have worked at Uber or 1 of these cab apps, and have great understanding of when/where to use different tools/databases. thx much! But 1 point these are so detailed (including the time that would take to draw each of those layouts and bullet points), and some of these sys design interviews are only for 45 minutes (which actually may be only 35 minutes leaving the 5 minutes each for intro/outro), can't cover everything, but we can at-least layout the buffet of knowledge we have and let them pick what they would want us to go over.

  • @KrithiHayagriva
    @KrithiHayagriva Před rokem

    Fantastic bro. Your teaching style and kind of substance you produce is awesome!

  • @avik1983
    @avik1983 Před 3 lety

    Very easy to understand & amazing!!

  • @TheVergilfrans
    @TheVergilfrans Před 2 lety

    Very good explanation...all scenarios covered.

  • @tusharshukla8099
    @tusharshukla8099 Před 14 dny

    Your way of explaining is fantastic bro,
    But pls change the mic voice would be more clearer

  • @madipallynaveenkumar6811

    Nice explanation!.. Liked it!

  • @avinashkumar3340
    @avinashkumar3340 Před 3 lety

    Superb explanation

  • @thinktough
    @thinktough Před 3 lety +3

    Hi, thanks for the content on this channel! Had one question though.. in the customer flow, we will need a load balancer that makes a web socket connection to the cab request service right? Since there can be multiple customer requests at the same time?

  • @pawandeepchor89
    @pawandeepchor89 Před 3 lety

    Very nice work 👍

  • @AlbertoRodriguez-oe6jo
    @AlbertoRodriguez-oe6jo Před 2 lety +1

    I think the complexity of maintaining redis to map driver id - handler and the reverse mapping also can be avoided.
    If we load balance the request from driver based on driver id hash, the request will go to the corresponding socket handler, and when the response comes back say driver gets a ride booked, the driver object will have the id from which corresponding handler can be found. Thereby eliminating the need to store mapping.

  • @satishverma5887
    @satishverma5887 Před 4 měsíci

    Very nicely explained

  • @rabindrapatra7151
    @rabindrapatra7151 Před rokem

    In many interview people ask algorithms in system design round. but I see your most of the design is like use kafka for self pace or decoupling, scaling. Redis for cache over mysql. It would be great if you can add algo in each explanation.

  • @edwardteach2
    @edwardteach2 Před 2 lety

    U a System Design God

  • @dharmendrabhojwani
    @dharmendrabhojwani Před 2 lety

    Good Content.

  • @sonufarkya3815
    @sonufarkya3815 Před 2 lety

    Thanks Sandeep ... Such a great video. just one thing so customer also connects with Map service to find out its location + the A(pickup) and B(drop point) point

  • @user-hh2fm8ob1d
    @user-hh2fm8ob1d Před 3 měsíci

    Our college project is not real project but it gives some insight. Similarly this video is just an insight. I think uber is more complex designed.

  • @bigmugable
    @bigmugable Před 2 lety

    Brilliant

  • @NikPnchl7
    @NikPnchl7 Před 3 lety +1

    Would using a quadtree be a quicker way of determining cabs in the same segment as the rider trying to hail a cab ?

  • @ourtravelgems
    @ourtravelgems Před 3 lety +10

    "Segment" is essentially a quad tree.

  • @amolnagotkar3037
    @amolnagotkar3037 Před 2 lety

    thnx for this video

  • @MrLightweb
    @MrLightweb Před 3 měsíci

    A great video, thanks man!
    Only one suggestion, please buy a better microphone :)

  • @kunal4350
    @kunal4350 Před 4 lety

    Thanks for your video.
    There are millions of customers , how does this enormous connection request is handled?

  • @juansebastianmartinez8951

    Hi, If I understand well the cab finder send a message to kafka and then location service get the message and put another message to kafka (Or the ACK contains the list?) with cabs and then cab finder send the notification to all of those cabs and request an acceptance, then when one of them accept the trip the cab finder response with the cab to the cab request service?

  • @manigandanganesan5778
    @manigandanganesan5778 Před 4 lety +3

    Why did you choose request response model for location update from driver? I think event driven model is more suitable for this. Please let me know your comments

  • @parthasarathikundu7418

    What is this LB doing ? In couple of diagram you have linked the D1 - > Websocket Handler1. It is not clear the other endpoint of WebSocket connection. Should be LB, right?

  • @rohan8arora
    @rohan8arora Před 3 lety +1

    would it not be easier to put driver locations in a kafka first and then have multiple consumers reading for location service? This way the load will be fairly balanced.

  • @kumarmanish9046
    @kumarmanish9046 Před 2 lety +1

    Very confused between roles of Location service and Map service. Who takes lat long and returns segment id ? Who identifies the list of drivers based on segment?

  • @pathakshardul
    @pathakshardul Před 3 lety +1

    Thanks for amazing content on the channel! Could you please clarify how would the maps service converts lat-longs to segment? I was thinking if the segment size is constant, it would just be a function of lat long, but with variable segment sizes (for avoiding too many or too few drivers), would you need an index?

    • @uditagrawal6603
      @uditagrawal6603 Před 2 lety +1

      I think here geohash can be one option where world is divided into 32 sections which keeps on dividing recursively and we can always derive a geohash from lat long which can serve as an identifier for the segment.

    • @yossarian2909
      @yossarian2909 Před 2 lety +1

      @@uditagrawal6603 Thanks or bringing up geohash -- it makes sense for the drivers to constantly publish their 8 or 9 byte geohash .. the precision for location management can be left to the "map service".. there wont also be a need to translate lat, long to a segment.

  • @PraveenKumar-vb2js
    @PraveenKumar-vb2js Před 3 lety +1

    Hi, thank you for uber hld design.
    I am looking for database design. What are table we have to create SQL db and what could be structure for no-sql db? Could you please help to have video on this? Or anyone have link which explain same please help share in comment.

  • @abcd12272
    @abcd12272 Před 3 lety +2

    How is redis updated when a driver's segment changes?

  • @9430057539
    @9430057539 Před 4 lety

    How the data related to trips is distributed? since it is a distributed system. it will not be feasible to store data into single instance of database? we need to do some sharding( even in cassandra we will need to choose distribution key ) so how the distibution/sharing of data happens?

  • @jkl89966
    @jkl89966 Před 2 lety

    Hi, can anyone help with this question: System design question to design a heatmap. user can input any range of times (in minutes) and I want to be able to see the density of drivers on the map color coded You don't have to worry about the actual color coding part (assume you have some UI that will take in the count input and do the coloring for you).

  • @nikitaparab1483
    @nikitaparab1483 Před 5 měsíci

    great content but please use better microphone.

  • @hiteshklalwani
    @hiteshklalwani Před rokem

    Cab finder is doing so many things, how do we handle spike in requests for it? Do we enqueue requests and spin up more instances of services?

  • @anushree3744
    @anushree3744 Před 3 lety

    How the ride sharing will be implemented? Say, user is trying to book a seat in a shared cab.

  • @pkr619
    @pkr619 Před 3 lety +4

    Great Video, one issue - can you please change your audio system, the audio quality is poor.

    • @codeKarle
      @codeKarle  Před 3 lety +9

      Yes Pratyush, we are experimenting with a couple of options these days.
      Looks like recording videos is a far more complicated thing than building software :)

    • @vidhanchandra3997
      @vidhanchandra3997 Před 3 lety +1

      @@codeKarle But these are saviours for people who are struggling to learn system design....

  • @ashleydorris1995
    @ashleydorris1995 Před 2 lety +1

    Great video! Watched 3 other videos and this one is the best by far. One thing though is you never mentioned what Location Service will write to Kafka. Can you please clarify this?

    • @rishabhkalra9505
      @rishabhkalra9505 Před 2 lety

      i think location service pushes events regarding payments and pricing. It was mentioned by the author that location service also calculates pricing and payments for drivers

    • @pakeshchauhan4202
      @pakeshchauhan4202 Před rokem

      Location service will send 1. details about route selected between source and destination and the time it takes. It will help improving MapService suggestions. 2. Route taken by driver is different from suggested route. It will help in Fraud Service, driver profiling, driver priority engine and user profiling.

  • @goutamkundu6392
    @goutamkundu6392 Před 2 měsíci

    when a new driver comes online and gets connected to a websocket, how the websocket manager gets to know the fact and how does it update mapping? Is it using internally a HashMap?

  • @varunleoin
    @varunleoin Před 3 lety

    Did system like Uber/Ola really uses Redis for storing location -- driver mapping ?

  • @adityakhare7073
    @adityakhare7073 Před rokem

    How can we scale the websocket handlers, if we have lakhs of drivers live at the same time how can we handle that? We just can't add more and more websocket servers right?

  • @kumarutkarsh7126
    @kumarutkarsh7126 Před 2 lety

    Can instead of segmentation by road distance. we take time

  • @MinekEzQM
    @MinekEzQM Před 2 měsíci

    Man... the content of your video is truly interesting and is worth to watch. But in 30 minutes you say "OK" about 200 times. I'm trying to focus on WHAT you are saying but my brain is just getting ready for the next "OK" (that I don't want to hear).
    Is it possible to get a sound engineer, who could remove all the "OK"s from the sound track and reupload the video in that form?

  • @arunraj2527
    @arunraj2527 Před 2 lety

    Seen a lot of videos of Uber design. GeeksForGeeks says its a 'Hard' problem. After watching your video, its not that hard it seems. Easily navigable.

  • @krishnashah3765
    @krishnashah3765 Před 3 lety

    If Uber stores driver data for every 5 seconds, the data stored is insanely huge. Data stored per day would be 30 bytes * (86400/5) * 1M Drivers. Around 500 GB per day. Around 300 TB per year just for storing driver location

    • @shashankshekhar8970
      @shashankshekhar8970 Před 3 lety +2

      I agree that this amount of data is huge, but this is primarily analytical data right. We wont be actively querying on it unless we need to do some analytics on it. so this data can be moved to something like Hive or even older data can be moved to Archive cold storage

  • @rishirajtandon3849
    @rishirajtandon3849 Před 3 lety +2

    Hi,
    In the video, you said we will keep the driver location in NoSQL DB, what would be the sharding key for cabs location data? To fetch fast their current location. The driver will be continuously moving after every 4-sec new location feed will come and the old location feed will be stale data.
    Please help.

    • @shashankshekhar8970
      @shashankshekhar8970 Před 3 lety

      Had a similar question, from the use case point of view it makes sense to keep the segment id as the partition key and in the wide columns add the various cabs. But the issue is a cabs segment keeps changing, so how do entry has to be deleted from older segment too, how do we do this since Cassandra does not support deleted very well

    • @uditagrawal6603
      @uditagrawal6603 Před 2 lety

      I think we are just concerned with the current location of the driver.
      So we can keep that in redis with key being driver_id and value being lat-lon and segment I'd.
      This in turn can help in deciding if driver has moved to another segment which can further be updated in the redis which also contains segment_id v/s list of driverids.

  • @andywang6856
    @andywang6856 Před 2 lety +4

    Thanks for the great video! I think the WebSocket Server stuff adds a bit unnecessary complexity. This way the web server is no longer stateless. Why cannot we store the trip-driver matching information in database, so every time drivers send location data the web server query the db to find assigned trip and return to driver if exists?

    • @zaidshaikh2536
      @zaidshaikh2536 Před 3 měsíci

      That's a write heavy operation which can result in slow queries (high latencies) which can degrade the performance

  • @randomguy4822
    @randomguy4822 Před 17 dny

    Can you please make HLD of Book my Show ?

  • @yuenyiupang
    @yuenyiupang Před rokem

    um...what happend when the driver is offline (car crash, no battery, phone break) or reject the trip, when you try to assign a trip to him, how to handle the confirmation ?

  • @princekm5902
    @princekm5902 Před 2 lety

    Can I specify that the system should be Real Time?

  • @idotsuk
    @idotsuk Před rokem

    why would you use mysql for user data?

  • @nitigupta123
    @nitigupta123 Před 4 lety +6

    You have mentioned that the location will be updated almost every 5 secs for drivers and Cassandra is a good for this as it will be able to scale. But in your DB video, you have mentioned that noSql should not be used for multiple updates. Can you please clarify?

    • @codeKarle
      @codeKarle  Před 4 lety +16

      Different databases(Nosql or others) are optimized for different kind of read-write patterns. Cassandra for example is great for inserts and reads, decent enough at updates, but bad at deletes. In this scenario of location pings, we are doing a insert every 5 seconds for a driver and then bulk reads by driver id when we need to plot the driver's/trip's trail. So for this scenario Cassandra would be a good choice.
      Hope that answers :)

  • @ameyjain3462
    @ameyjain3462 Před 2 lety

    make one for coding platform like leetcode

  • @ayushman_sr
    @ayushman_sr Před 3 měsíci

    is webscocket horizontal scalable

  • @ayushman_sr
    @ayushman_sr Před 3 měsíci

    I hope you must have upgraded your microphone by 2024

  • @user-hh2fm8ob1d
    @user-hh2fm8ob1d Před 3 měsíci

    why catn we use lat long instead segment

  • @mrdime9318
    @mrdime9318 Před 3 lety +1

    Can I know how some founders of the app did this complex thing by themselves ?

    • @ahmadsaeed7168
      @ahmadsaeed7168 Před 3 lety +2

      First few years are always monolith and some basic features.

  • @sahilarora1794
    @sahilarora1794 Před 2 lety

    Hey Sandeep, Great content. Just few doubts :
    How do we divide the area into segments as you mentioned?
    Why we have different driver service, we could just include one field as role ( user/driver) and utilize same service only?

    • @andybhat5988
      @andybhat5988 Před 2 lety

      Typically quad tree is used for dividing the area into segments. Check Google S2 library for details

  • @nehasht2
    @nehasht2 Před 2 lety

    It's like sectors of telecom towers 😀 and do visitor stuff , local to the area...only correct usecase of Cassandra is trip history...can we use weighted graphs to calculate minimum distance? shouldn't we draw circles rather than segment because it will be equidistant and all cabs with in that radius can be then selected based on requirement

  • @Imrohanroy
    @Imrohanroy Před 2 lety

    Speed up the video to 1.5 and thank me later :+1

  • @gopalakrishnarao4273
    @gopalakrishnarao4273 Před 3 lety +2

    minute correction. it's (1,0) on x-axis and (0,1) on y-axis

  • @umer7936
    @umer7936 Před 3 lety

    Hello, Can your company or someone who you may know develop a software like Uber for my rideshare company? please reach out to me.

    • @codeKarle
      @codeKarle  Před 3 lety

      We can provide consultation, but not the full implementation at this point in time. Please let us know if that works.

    • @Pythonnaire
      @Pythonnaire Před rokem

      Hello Umer, Have you already started development?

  • @04minutes53
    @04minutes53 Před rokem

    Good One Buddy ...But Please focus the camera on the board rather than your Face. That will help

  • @kumarswaminathan6375
    @kumarswaminathan6375 Před 6 měsíci

    The white board is often hidden by the instructor. It would be best if these were slides and the relevant portions are highlighted using markers or shading techniques. The instructor's video can be relegated to a thumbnail except at start and end. Good content but poor presentation.

  • @thenighthoughts
    @thenighthoughts Před 7 měsíci