Kafka vs. RabbitMQ vs. Messaging Middleware vs. Pulsar

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

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

  • @MobileComputing
    @MobileComputing 7 หลายเดือนก่อน +84

    Cool, some names of MQ tools were mentioned. Where is the "vs" in "Kafka vs. RabbitMQ vs. Messaging Middleware vs. Pulsar"?

  • @chetankhandave
    @chetankhandave 7 หลายเดือนก่อน +55

    Very good information, but it can much better if you explain how Stream processing works in Kafka , RabbitMQ, Pulsar. Polling and pushing in each techniques is very important to know.

    • @jayrigger7508
      @jayrigger7508 7 หลายเดือนก่อน +2

      sounds like a good thing for you to work on and post yourself on own channel

    • @alexw1306
      @alexw1306 7 หลายเดือนก่อน +9

      @@jayrigger7508 why so arrogant? He literally suggested a potential improvement and you come by and say "Just do it yourself".

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

      That’s not an improvement, but literally a different topic.

  • @CalifornianViking
    @CalifornianViking 7 หลายเดือนก่อน +23

    @ByteByteGo - Thanks for another good video.
    A word of caution. While message queues are impressive, they are often misapplied. I have seen message queues make systems slower and less reliable while consuming a lot of resources that could have been used to speed up other parts of the system.
    It would be great if you could create a video that explains when (and when not) to use a message queue.

    • @br.3250
      @br.3250 7 หลายเดือนก่อน +1

      Do you know anything about that, I'd certainly be useful

  • @fadthegreat
    @fadthegreat 7 หลายเดือนก่อน +3

    wow, within 4min we already get and understand the high level of each message queueing from old to latest. Thank you

  • @NielsBasjes
    @NielsBasjes 7 หลายเดือนก่อน +1

    Love your videos. You mentioned exactly once semantics as a feature of Kafka. I have found that another game changer is the capability of building systems that also maintain a guarantee of message order per key (usually a session id) which makes all of it (often in combination with Apache Flink) suitable for a whole new class of applications.

  • @miran248
    @miran248 7 หลายเดือนก่อน +20

    Worth mentioning is also (jetstream) nats, trivial to scale, has routing, partitioning, queueing, pub sub; it also has key value store, object store.
    Imagine if kafka and redis had a baby.

    • @rogsiel
      @rogsiel 7 หลายเดือนก่อน

      Wow, didn't know of it. Specially the object store seems cool

    • @miran248
      @miran248 7 หลายเดือนก่อน +1

      @@rogsiel While i haven't used their object store yet, i am using the key value store to persist actor's internal state, that way i don't need to rebuild it (event sourcing pattern) before processing the requests.
      The only issue i have with nats is the lack of backup / recovery options, seems like replication + a recovery cluster is the preferred way.

    • @rogsiel
      @rogsiel 7 หลายเดือนก่อน

      oh that's cool . Will definitely look into it. Having pub/sub and object store together is interesting.
      I'm already doing the exact same thing for backups and persistent data.

    • @nikitamyazin6586
      @nikitamyazin6586 7 หลายเดือนก่อน

      Nats doesn’t have partitioning, and apparently never will. You can emulate it with channels, but you won’t get rebalancing, for example. So it’s more like a cousin to Kafka

    • @miran248
      @miran248 7 หลายเดือนก่อน

      @@nikitamyazin6586 Are you talking about jetstream topics or old nats streaming server (stan)?
      You can have multiple consumers on the same topic and as long as they belong to the same group they will all act as one.
      You can also partition topics, based on some (hashed) key and split incoming traffic across multiple workers, so that the same topic always reaches the same worker, which is very useful with actors.
      I'm sure you've seen this and we're just thinking of different kinds of partitioning.
      docs DOT nats DOT io/nats-concepts/subject_mapping

  • @madhujai_shiksha
    @madhujai_shiksha 6 หลายเดือนก่อน +1

    Its good know abt latest tech trends and tools but challenging part to learn where to use them in overall system. Breaking a system into different apps is most challenging thing in real world which can only be learn by experience

  • @ament4069
    @ament4069 7 หลายเดือนก่อน +2

    Each diagram seems so informative
    Thank you

  • @kervinpeguero4468
    @kervinpeguero4468 5 หลายเดือนก่อน +1

    Hi, I do not know your name, but I really enjoyed your videos and learned so much from them. In the diagram, (0:17min) I think there is a typo in the flow from passenger management to notification shouldn't be "Notify Driver" instead of "Notify Passenger" or invert the flow from the notification queue to passenger. If I'm wrong, please let me know if you have time of course. Hope you have a really nice day or night Mr. and keep going.

  • @jpzhao19403
    @jpzhao19403 5 หลายเดือนก่อน +2

    The animated flow charts and diagrams are very impressive, which tool did you use to create those?
    BTW all the videos you created are super high quality in both content and presentation, great job!

  • @hentie5371
    @hentie5371 7 หลายเดือนก่อน +8

    What is XXX would be better title. There is no 'vs.' in the whole video. If I just throw this video's content to my tech design spec as explanation of why I picked Kafka over RabbitMQ or another way around, I will probably have to look for another job again.
    When we talk about 'vs.' we should go from advantages, disadvantages, use case (this was mentioned). No advantage or disadvantage for one over another has been mentioned throughout the video.

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

      cry nub

  • @JonathanDieu
    @JonathanDieu 7 หลายเดือนก่อน +3

    Thank you for continuing to create such helpful resources! 🐐

  • @sanapramesh
    @sanapramesh 6 หลายเดือนก่อน +1

    Should the arrow from driver management to notification be labeled as "NOTIFY DRIVER"?

  • @RahulSingh-pd1cr
    @RahulSingh-pd1cr 6 หลายเดือนก่อน +2

    Which tool has been used for this graph can anyone tell me

  • @szsz2277
    @szsz2277 7 หลายเดือนก่อน +1

    This is great information! Thanks for the video. Can you do a video explaining and reviewing some of the top Platforms as a Service options? Eg. Heroku, Render, Digital Ocean, Vercel, Fly, etc. When to use them and which ones are better for which job? Thank you.

  • @artemvasilyev1637
    @artemvasilyev1637 6 หลายเดือนก่อน +2

    what service do you use to draw these animations?

  • @ManticoreRoko
    @ManticoreRoko 7 หลายเดือนก่อน +7

    Why are you forget Redpanda(and Redpanda ecosystem)?? Redpanda is most powerful streaming solution today working C++ and GO under hood + Kafka Api. Please talk about Redpanda too

    • @angryktulhu
      @angryktulhu 7 หลายเดือนก่อน +2

      No 😂

    • @wind1309
      @wind1309 7 หลายเดือนก่อน

      vendor lock in ecosystems get outta here

  • @maverickmaverick5
    @maverickmaverick5 5 หลายเดือนก่อน +1

    If we buy ByteByteGo subscription will you share your powerpoint clip arts ?

  • @MelroyvandenBerg
    @MelroyvandenBerg 7 หลายเดือนก่อน +2

    I don't like the cloud focuses solutions. Like the latest you showed. I want to run a message queue system on prem.

    • @manofacertainrage856
      @manofacertainrage856 7 หลายเดือนก่อน

      I've spent a few years with a RabbitMQ backed system on-prem. Granted, on-prem, on a VM on desktop/laptop, and on-prem in a VM in a llocal data center are all about the same thing these days. Failure modes and recovery aren't always obvious (especially if the VM is frozen and moved), but it's at least a decent solution and might be a great one depending on your circumstances.

  • @jopa19991
    @jopa19991 5 หลายเดือนก่อน

    While Pulsar is evolution of a message queue in one way, it lacks exactly once delivery policy, which is Kafka is famous for the most

  • @igorvizma4493
    @igorvizma4493 2 หลายเดือนก่อน +1

    It is described as evolution of MQs when it's basically different features of MQs. If one has high load requirements then it's definitely Kafka it is simply an MQ and it's incredibly fast without any feature on top, in it's turn RabbitMQ has many features like shovels, delayed/dead-letter queues almost out of the box. The video is very superficial and definitely does not compare MQs against each other.

  • @graymcd
    @graymcd 7 หลายเดือนก่อน

    Don't forget about Microsoft Message Queue (MSMQ), it's still there.

  • @zx1986
    @zx1986 7 หลายเดือนก่อน +1

    how about NATS?

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

    Great video
    How do you design animated diagram?

  • @dquangminh1991
    @dquangminh1991 7 หลายเดือนก่อน

    can i ask what tool to created animated diagrams like that ?

  • @Global-Glimpses-Vlogs
    @Global-Glimpses-Vlogs 7 หลายเดือนก่อน

    How do you make these slides? What is the tool name?

  • @Flako-dd
    @Flako-dd 7 หลายเดือนก่อน +1

    I looked into Pulsar recently, looks really powerful. Anybody got real-world experience already?

  • @raj_kundalia
    @raj_kundalia 7 หลายเดือนก่อน

    Thank you for doing this!

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

    Excellent! Many thanks :-)

  • @alamba78
    @alamba78 7 หลายเดือนก่อน

    How do you create the animations? After Effects or built-in animation with Power Point?

  • @devalshah69
    @devalshah69 7 หลายเดือนก่อน +2

    anyone have used ZeroMQ?

  • @ihsanpro9406
    @ihsanpro9406 7 หลายเดือนก่อน +2

    How do you exclude NATS from here ? Come on man !

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

    Ibm mq supports hardware failures - not so sure.
    We ran it at a fairy large company - once a new service without proper disposal code took down MQ node, no one could publish or consume a message

  • @benzazalaid6623
    @benzazalaid6623 7 หลายเดือนก่อน

    hin and goog luk, please what s the sofwre wich you make your presentation

  • @JonnyJiang-c4m
    @JonnyJiang-c4m 5 หลายเดือนก่อน

    how about rocketmq?

  • @RtoipKa
    @RtoipKa 7 หลายเดือนก่อน +1

    I see Kafka is often used as message queue which it is not.

    • @qm3ster
      @qm3ster 7 หลายเดือนก่อน

      Persistent sharded logs as the source of truth 🥵

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

    please do Spark and Hadoop

  • @SkEiTaDEV
    @SkEiTaDEV 7 หลายเดือนก่อน +1

    theres an incredibly nasty high pitch noise until 0:12

  • @spouter
    @spouter 7 หลายเดือนก่อน

    We would need implementation too for all the tools you have explained.
    Please make videos on those too.

  • @shinobi77
    @shinobi77 7 หลายเดือนก่อน +1

    How about Redis Pub/Sub?

  • @samjackgreen
    @samjackgreen 7 หลายเดือนก่อน +1

    From this video, I don't understand how there was an "evolution". It seems you are just naming arbitrary virtues of each messaging system... Very hard to follow. Cheers.

  • @ChrisWard74
    @ChrisWard74 7 หลายเดือนก่อน

    Which you had included product from Microsoft in this comparison.

  • @JohnSmith-op7ls
    @JohnSmith-op7ls 7 หลายเดือนก่อน +81

    Programming content creators: Want to know how companies you’ll never work for do things the companies you will work for don’t need to do?

    • @oskarszwajkowski
      @oskarszwajkowski 7 หลายเดือนก่อน +9

      Or giving you freshest framework/tool so you can rewrite your application again for no reason at all 😅

    • @JohnSmith-op7ls
      @JohnSmith-op7ls 7 หลายเดือนก่อน +2

      @@oskarszwajkowski Trend casing, when you need an excuse to not do real work

    • @matonolo
      @matonolo 7 หลายเดือนก่อน +15

      U are just mad because u cant handle more advance concepts than programming.

    • @herdenq
      @herdenq 7 หลายเดือนก่อน +6

      ​@@matonolo "More advanced concepts than programming".. what?

    • @JohnnySacc
      @JohnnySacc 7 หลายเดือนก่อน +19

      Event-driven microservice architecture is important to know if you want to work in backend. Not sure why you're acting like this is impractical knowledge.

  • @5353055
    @5353055 7 หลายเดือนก่อน

    how about rocketMQ?

  • @Zmey5656
    @Zmey5656 7 หลายเดือนก่อน

    I use only Kafka. May be I nee to try something new.

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

    RabbitMQ is fine 😊

  • @Fahad-et3sc
    @Fahad-et3sc 7 หลายเดือนก่อน +1

    one day i will understand all this lol

  • @JohnLee-o3j
    @JohnLee-o3j 3 หลายเดือนก่อน

    Jaunita Ridge

  • @LindaMartinez-l1l
    @LindaMartinez-l1l 4 หลายเดือนก่อน

    Cordelia Fields

  • @JoseLee-o5p
    @JoseLee-o5p 4 หลายเดือนก่อน

    Collins Meadow

  • @ianjohnson2433
    @ianjohnson2433 7 หลายเดือนก่อน +1

    Bro i think you are well knowledgeable but to help,why not indicate by doing than just explaining?I have never seen you code or apply these concepts.

  • @LindaMartin-d2h
    @LindaMartin-d2h 4 หลายเดือนก่อน

    Treutel Island

  • @suvankarpaul8659
    @suvankarpaul8659 7 หลายเดือนก่อน

    🫡

  • @alexalexin9491
    @alexalexin9491 7 หลายเดือนก่อน +6

    Oh please, you must've beaten all records of unintelligibility in this video. I struggled to understand the simplest words you sais instead of getting the main ideas of the video. Can you please work on your prounciation a little, PLEASE?

    • @mtsmithtube
      @mtsmithtube 7 หลายเดือนก่อน +3

      There's a transcript option

    • @hmaina0
      @hmaina0 6 หลายเดือนก่อน +4

      this is a you problem, video is well explained. maybe you should learn some basics first.

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

    Kafka uses an inefficient pull mechanism where consumers keep polling the broker. With time it will lose steam like Cassandra