From Web to Flux: Tackling the Challenges of Reactive Programming By Victor Rentea

Поделиться
HTML-код
  • Опубликовано: 20 янв 2025

Комментарии • 38

  • @aksh1618
    @aksh1618 Год назад +18

    What a showman 🙌🏼 I have never had this much fun with anything related to reactive programming!

  • @harshadkumarshrishrimal1728
    @harshadkumarshrishrimal1728 Год назад +6

    Very well done presentation. Thank you.

  • @zerocoolys
    @zerocoolys Год назад +5

    The best talk about reactive programming that I had ever watched, with case by case.

  • @JorisOosterhuis
    @JorisOosterhuis Год назад +7

    Amazing talk. It helped me grasp some of the concepts of reactive i had not understood till now. Thanks!

  • @hokagetn5181
    @hokagetn5181 Год назад +9

    Best video on reactive webflux

  • @timcsq
    @timcsq 8 месяцев назад +6

    Impressive as it is, Virtual Threads make 99% of it obsolete.

  • @10xtenx10xtenx10xten
    @10xtenx10xtenx10xten Год назад +6

    Does anyone know what tool he is using to all the arrows?
    Edit: It's ScreenBrush app for Mac.

  • @Archanava-s5s
    @Archanava-s5s Год назад +4

    Thanks for the awesome content and what an engaging and entertaining talk!!

  • @RaghavSharma2211
    @RaghavSharma2211 Год назад +3

    Love the way you teaches us!

  • @eugeneyarmack3467
    @eugeneyarmack3467 2 месяца назад

    This guy is a GOAT! Super helpful and informative.

  • @tendaipfidze7933
    @tendaipfidze7933 7 месяцев назад +2

    Had almost given up on reactive until this guy showed up 👏👏

  • @faranak-cs
    @faranak-cs Месяц назад

    Outstanding Talk!!!

  • @goldie75c
    @goldie75c Год назад +4

    Project Loom equivalent presentation would be interesting to compare 😇

  • @razamustafa3847
    @razamustafa3847 20 дней назад

    where I can find the repo link of above ?

  • @MrOcelot92
    @MrOcelot92 8 месяцев назад

    1:50:50 isn't row 50 Mono too? why there is no need to add a return something there too?

    • @timcsq
      @timcsq 8 месяцев назад

      delayUntil subscribes to the inner code but returns the original item, which is the saved post from line 43 in this case. You can think of it like it's a procedure which executes its body, but then returns its argument (something like "Long myProc(Long arg) { return arg }"). That's why you can map this saved post into a Long using getId and return that ID as Mono.

  • @zvejkal2
    @zvejkal2 8 месяцев назад

    Great performance and presentation style. I really enjoyed it!

  • @shane-kung
    @shane-kung 11 месяцев назад +2

    any chance sharing the repo?

  • @lukasz-cpu2416
    @lukasz-cpu2416 Год назад +4

    Reactive programming is cool for the kind of tasks you show in your presentation like CRUD operations. When it comes to projects where we have a very complex business domain, there are many different exceptions, rules, checks and so on reactive code becomes harder and harder to maintain. We have a situation where we have pipelines of 10 lines each with a Map/FlatMap for example. Not to mention how to diagnose the error in production or performance issue. I don't wish this on anyone. In summary, reactive programming is cool for easy applications, building data transfers but nothing more. Peace

    • @TJ-hs1qm
      @TJ-hs1qm Год назад

      how? if every function is total combining those will give a total function. To better understand performance pure functions can be compared to imperative style coding using local mutable state, ex. for-loops instead of recursion. And due to referential transparency different coding styles may be mixed as long as they stay pure and total.

  • @steli1992
    @steli1992 3 месяца назад

    where can we find this repo?

  • @avalagum7957
    @avalagum7957 Год назад +1

    If your machine cannot process data coming to it fast enough, then you use reactive to tell the data producer to slow down. Does that mean the data producer has some way to hold the data? Does that mean that instead of holding the data in our machine to gradually process it, we hold the data in the data producing machine to gradually release it? Does that mean we only move our issue from this machine to another machine?

    • @aksh1618
      @aksh1618 Год назад +1

      The idea is to have an end-to-end reactive chain, where each part takes care of their responsibility, until the final publisher. So if you're using a mongodb reactive driver as the final publisher, it can take care of the "tough" job of how to handle backpressure, and the intermediate producers and consumers just have to take care of propagating it to the source. So the "issue" keeps getting propagated till it becomes mongodb's issue, which knows how to deal with it. (Disclaimer: This is a very simplistic view for the sake of a direction towards the answer.)

    • @phanvanhoa
      @phanvanhoa Год назад

      Ideally, the producers produce, the consumers consume. Typically there's a buffer in the middle ( databases, message queues, kafka topics, ... etc).

    • @avalagum7957
      @avalagum7957 Год назад +1

      @@phanvanhoa if I'm getting data from a database, how can I tell the db to give me data slowly enough so that I can consume it without using reactive?

  • @Tenesh45
    @Tenesh45 Год назад

    Very good explanations and I really liked playing the right sounds at the right time 😂

  • @neotechfriend
    @neotechfriend 7 месяцев назад +1

    ❤ superb!

  • @prabhatism
    @prabhatism Год назад +1

    1:39:31 i wasn't ready for it! xD

  • @РоманПивоваров-ф7ш
    @РоманПивоваров-ф7ш 2 месяца назад

    The Legend!

  • @simonmassey8850
    @simonmassey8850 10 месяцев назад

    I have literally been through this whole learning curve with some folks how had not programmed in scala as I had. It was complete carnage 😂

  • @pnadmin7927
    @pnadmin7927 8 месяцев назад

    amazing!!!

  • @joaoandrade4239
    @joaoandrade4239 9 месяцев назад +1

    Java 21, the Reactive webflux Killer?

  • @theprince08853
    @theprince08853 Месяц назад

    I can't believe I have to use this shit at work. 30 mins in and I already know I'm going to have to repeat parts of the video.

  • @alphanarslan7390
    @alphanarslan7390 Год назад

    awesome

  • @TheMrDrakiula
    @TheMrDrakiula Год назад +8

    Lord have mercy on those that have to read and maintain this kind of code, not to mention those that are new to this kind of project. Just horror and nightmares. Luckily there are other ways in the world.

    • @MakeItStik
      @MakeItStik Год назад +1

      I have read and maintaining such application. What are the other ways you suggest ?

    • @simonmassey8850
      @simonmassey8850 10 месяцев назад +1

      Tomorrow Java 22 comes out with the 2nd preview version of “structured concurrency” where you can write blocking code with 1,000,000 virtual threads and clear stack traces. Then you can write obvious code that scales without it needing to use a reactive framework that must do complex things to juggle traditional threads.