Optimistic Locking - What, When, Why, and How?

แชร์
ฝัง
  • เผยแพร่เมื่อ 12 ม.ค. 2025

ความคิดเห็น • 29

  • @abdulwakeel6363
    @abdulwakeel6363 ปีที่แล้ว +14

    This channel has enough content to become a senior backend engineer who are at beginner or mid senior level. Thank you Arpit so much

    • @cooldudecs
      @cooldudecs ปีที่แล้ว

      My goal is Staff is so this has been great , even for references to modeling what already is out there rather than re inventng the wheel. Thanks!

    • @thegreekgoat98
      @thegreekgoat98 ปีที่แล้ว

      Hey Abdul, can you please tell me where to start. Right now I have just passed out in 2023, and joined a company as a backend developer.

  • @sandy4799
    @sandy4799 8 หลายเดือนก่อน +3

    This is really awesome. Got satisfying answers for the doubts I had on contention for CAS operation by two threads. If one wants to be like him your thinking should be like DFS graph traversal, keep digging the problem deeper until all your doubts are resolved.

  • @jaimalad2902
    @jaimalad2902 ปีที่แล้ว +1

    Great teaching technique. Awesome videos. There lot of senior engineers but very few of them has such great teaching skill like arpit

  • @rahulkapoor7305
    @rahulkapoor7305 11 หลายเดือนก่อน +1

    In optimistic locking there is a concept of Time-of-check to time-of-use
    when we are checking the old value to be old value => so that we can write it to the new value.
    there can be another thread which will actually update it in the time being of this checking and updating.
    and current thread might be a case of also picking up old value = old value.
    here the race condition might occur

    • @samworldpk
      @samworldpk 9 หลายเดือนก่อน +1

      Please help me in this scenario,
      If my app is load balanced and I have 2 nodes running under it.
      When 2 requests arrived to update the same resouce. How can Optimistic Locking works?
      There will be 2 machines and each can execute compare_and_swap or (TOC and TOU) same time.

  • @aditya7955
    @aditya7955 ปีที่แล้ว +5

    Quick question around cpu context switch.
    Most CPU’s have multiple cores and this comparison function would be running on a single core.
    Does that mean other cores are also at halt for the time being or they can execute a parallel thread?

    • @AsliEngineering
      @AsliEngineering  ปีที่แล้ว +5

      It depends on the architecture. Some block the cores, while other block the memory location.

    • @joobis.b4568
      @joobis.b4568 ปีที่แล้ว +1

      @@AsliEngineering had this question in mind, thanks for clarifying

    • @SomeshSharma-z4z
      @SomeshSharma-z4z 4 หลายเดือนก่อน

      @AsliEngineering In the architecture where the other cores gets blocked, Are we using locks (if yes then won't it be a pessimistic approach)?
      And how is it implemented?

  • @vaishnavpureddiwar3091
    @vaishnavpureddiwar3091 8 วันที่ผ่านมา

    Thanks Arpit

  • @bhanuarora4504
    @bhanuarora4504 10 หลายเดือนก่อน

    Amazing content, these internals are very interesting, thank you so much arpit

  • @advaitpundlik8797
    @advaitpundlik8797 ปีที่แล้ว +1

    Great Video !!! I wonder how do you choose your content and what resources you used to learn fundamental concepts in multithreading ? Really Great Work and I look forward to every new video.

  • @prashantgupta6160
    @prashantgupta6160 ปีที่แล้ว +1

    Amazing bro, learned a lot

  • @sachinpandhare5143
    @sachinpandhare5143 ปีที่แล้ว +1

    Nice! But example is misleading, if goal is to just increase the count, then atomic increment is a better choice, better example for compare and exchange would be implementing mutex itself or spinlock, correct me if I am wrong :)

  • @nehagour6928
    @nehagour6928 2 หลายเดือนก่อน

    Wow explanation Arpit

  • @shishirchaurasiya7374
    @shishirchaurasiya7374 ปีที่แล้ว

    Today, I realised going through the content only once is not enough, as a human we loses many important points, finally completing this series for the 2nd time 😍😍 and what I am feeling right now I can't even express, feeling like I can be a TEAM LEAD 😅 at this time by knowing these little little minute details

  • @ashishsinghchauhan6304
    @ashishsinghchauhan6304 ปีที่แล้ว

    Good tutorial Arpit sir.

  • @samworldpk
    @samworldpk 9 หลายเดือนก่อน

    Please help me in this scenario,
    If my app is load balanced and I have 2 nodes running under it.
    When 2 requests arrived to update the same resouce. How can Optimistic Locking works?
    There will be 2 machines and each can execute compare_and_swap or (TOC and TOU) same time or a race condition may be.

  • @ShubhamVarshney-o7c
    @ShubhamVarshney-o7c 9 หลายเดือนก่อน

    arpit bhaiya ji please recommend a book to learn all of these CPU instructions and also linux commands for accessing process control blocks

  • @LeoLeo-nx5gi
    @LeoLeo-nx5gi ปีที่แล้ว

    Thanks a ton, it was quite clear!!

  • @charan775
    @charan775 2 หลายเดือนก่อน

    what about using pessismistic locking + skip locked? this will help in threads not getting blocked right?

    • @AsliEngineering
      @AsliEngineering  2 หลายเดือนก่อน

      Yes. It will, but it should suit your usecase. Because not everytime you can skip locked rows.

  • @queenslayerthefifth1771
    @queenslayerthefifth1771 6 หลายเดือนก่อน

    Why loading the count variable is atomic?

  • @rajatmehta8499
    @rajatmehta8499 ปีที่แล้ว

    This CaS operation is used in lmax disruptor too

  • @SaketAnandPage
    @SaketAnandPage ปีที่แล้ว

    Using complex variable name.

  • @Xresus
    @Xresus ปีที่แล้ว

    Bro Hindi mein Bana sakti ho ,agar ATI ho to
    English mein content bhaut hai youtube par
    Par Hindi mein kam😅