Nest.js Kafka Microservice Tutorial

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

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

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

    Get my highly-rated Udemy courses at a discount here: michaelguay.dev/udemy/

  • @renends7615
    @renends7615 2 года назад +6

    In a short time, something complicated was simplified.
    Great tutorial.

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

    Awesome tutorial! Just a heads up - for anyone using NestJs 10+ and @nest/microservices ^10, the data field contains the value itself (data.value will be undefined)

  • @maksymbaranovskyi8362
    @maksymbaranovskyi8362 7 месяцев назад

    Amazing. Your tutotials are concise, clear and packed with essential info. Thank you!

  • @mitchross2852
    @mitchross2852 2 года назад +41

    Hi, Can you follow up this video to dead letter queue, error handling, message repeat, load balance etc. Alot of people who use kafka use it at a enterprise-level for log replication, backups, redundancy. Can you make a another simple video like this for handling real world scenarios?

  • @thangapandianponnuchami4473
    @thangapandianponnuchami4473 2 года назад +8

    Wonderful content man! You are one of few creators who make short and clear. I am watching all your videos even if I aware of the topics to see your perception. Eager to wait for more content :-)

    • @mguay
      @mguay  2 года назад +2

      Thank you so much! This is greatly appreciated.

  • @GuilhermeSilva-vn6fw
    @GuilhermeSilva-vn6fw 7 месяцев назад

    You simplified a lot of things and have wonderful teaching skills, thank you

  • @michielsw
    @michielsw 2 года назад +2

    Thanks for taking the time to code out our suggestion from the previous video, appreciated!

    • @mguay
      @mguay  2 года назад +1

      Sure, thanks for the great suggestion!

  • @lord4791
    @lord4791 2 года назад +2

    Awesommeeeeeeee !
    Please make more Microservices with nest & react

  • @funnyclipz520
    @funnyclipz520 2 года назад

    Awesome tutorial.... finally found a good tutorial of Kafka with example using NodeJS

  • @NilsMoller
    @NilsMoller 2 года назад +2

    Hello, future man speaking here. `data.values` is not a thing anymore, the `data` object is now directly the DTO.
    Nest version: 9
    KIafkajs version: 2.2

  • @AmirMo_Razmi
    @AmirMo_Razmi 2 года назад

    you save me from my nightmares from my project, bro

  • @mohammedriyadh120
    @mohammedriyadh120 2 года назад

    Hi Michael, Thanks a lot for the great channel, i will appreciate it if you can go much deeper with kafka clients and consumers options

  • @digvijaysinghthakur2903
    @digvijaysinghthakur2903 2 года назад +1

    Tutorial is really helpful for beginners

  • @moylababa8196
    @moylababa8196 2 года назад

    I found your channel today and subscribed immediately. your channel is full of awesome tutorial. keep up the good work. Besh wishes

  • @까망색-j6q
    @까망색-j6q 3 месяца назад

    thanks this is the awesome tutorial for beginners

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

    if you are new to microservices, do not forget to have you rabbitMQ server running before you start this trying to connect here

  • @oyinlolaolasunkanmi
    @oyinlolaolasunkanmi 2 года назад +3

    Hi Michael, thanks for this tutorial. It is worth every minute of my time. I have a very important question. How do we send back a response to the API gateway, which is intended for the frontend application ? Lets say billing was successfully and frontend application needs a feed back in order to proceed or cancel the order. How do we implement this ?

    • @mguay
      @mguay  2 года назад +3

      Thanks! Continually polling the backend, Websockets, or a refresh button are some common approaches.

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

    Hi Michael, thank you for sharing, for some reason .Everthing is working well but I'm getting an undefined when a consume the event, probably my kakfa configuration is different

  • @kpeople96
    @kpeople96 4 месяца назад

    Noob Question:
    Shouldn't the API Gateway also implement a message pattern while communicating with the billing service. An Order would go to Gateway -> Billing -> Auth and it would need to return as response back to the user via same Gateway so that the billing was successful?

  • @permanar_
    @permanar_ 2 года назад +1

    I have a question, lets say like we want to share the same Data Types between Billing and Auth for the handleOrderCreated from billing microservices. Like when we send a message right, then subscribe to it and get a callback with a params inside it, how do we want to make it like predictable? Like what is the "inside" of this particular param?
    How do we do this?

    • @permanar_
      @permanar_ 2 года назад

      You called the `user.stripeUserId` because you "know" whats inside the object. But then how do we make it like type-safe and predictable?

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

    Ha. Not what I expected. I'm used to microservices communicating via pub sub using various cloud message buses. This tutorial looks to me awfully like the dreaded "distributed monolith' - the microservices in this video all seem to have to know about each other, rather than just emitting an event and not knowing or caring what other services might consume those events...The 3 services are tightly coupled - this ends up messy, hard to understand when you have many microservices. Kind of misses the whole point of microservices, for me, anyway. Fair comment or did I miss something? I'm surprised. NestJs has always seemed better thought through in it opinions than this... is it really encouraging direct service to service comms as the default ? Or is that just how this example does it?

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

    Could anyone comment pros and cons between setting up kafka consumer as a microservice vs as a Nestjs module as in previous tutorial?

  • @10_manhcuongnguyen87
    @10_manhcuongnguyen87 Год назад

    Hi, first of all thank you for this video. I implemented according but only get empty memberAssignment as {}

  • @Varuag89b
    @Varuag89b 2 года назад +1

    Great content as always 👏
    Keep up the good work 👍

    • @mguay
      @mguay  2 года назад

      Thank you very much.

  • @sajankumarvijayan811
    @sajankumarvijayan811 Год назад +2

    Wondering if is it possible to achieve this using mono repo? Because I want to avoid code duplication and manage single node_modules. The way you set it up works but I wonder wouldn't be a bit difficult to maintain the project code base in the long run?

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

      Also wondering about this

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

      Yeah, this seems like not the right approach tbh.. Pretty sure nest is supposed to manage this.

  • @tuanphamanh62
    @tuanphamanh62 2 года назад +1

    Hi. In my case, I just got the undefined value just because my payload in eventPattern does not have value property. I don't know why it is different with the video .
    Please share if you know the difference with me.

    • @darrenhudson1033
      @darrenhudson1033 2 года назад

      I had the same issue and just used the data object without calling data.value. may be a change in the JSON.stringify maybe?

  • @saurabh9446
    @saurabh9446 2 года назад

    I am getting this error - "The group coordinator is not available". I am using docker-compose with WSL2 on windows home

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

    pretty nice. Big ups 👍

  • @kisstamas6675
    @kisstamas6675 2 года назад

    I learned about microservices it is the very best when the services are fully independent from each other. That means they are not communicating directly with each other, but only with events. In this video you are useing the both way to communicate with services, it's weird for me. The independency between microservices is crucial, because they can not effect each other processes (when one service terminated unexpectedly the other services have to work fine). If it necessery you have to store data redundant on each service.
    What do you think about that?
    Actually this is a very good video :)

    • @mguay
      @mguay  2 года назад +1

      I agree this approach can come with some baggage. Check out my other Nest.js + Kafka video for a more decoupled approach.

    • @kisstamas6675
      @kisstamas6675 2 года назад

      @@mguay thank you, i'm following you, so i will check your videos ;)

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

    Great content 🤩

  • @zhangshiyucao
    @zhangshiyucao 2 года назад

    this is gold, thank you

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

    How to keep nodemodules common for all services ?

  • @muhammadnaveedashfaq2991
    @muhammadnaveedashfaq2991 2 года назад

    Amazing content. Thanks

  • @arslananjum416
    @arslananjum416 2 года назад

    Can anyone tell, how to create API with implementation of kafka in nodejs?

  • @chaouchsofien7988
    @chaouchsofien7988 2 года назад +1

    hello , thx for the video , what is the difference between this approach and the other approach you did it in the other video using only kafka js , is it the same ?

    • @mohammad-e6d9b
      @mohammad-e6d9b 6 месяцев назад

      me too . its not clear for me .

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

    Nice one

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

    Hi amazing video! I have a issue, I have a macbook M1 and tried to use docker-compose for intall kafdrop but I had a error.
    Can you have a mac M1? Do know how to install kafdrop in M1 machines?
    Thanks!

  • @ninabohm1535
    @ninabohm1535 2 года назад

    Great tutorial, merci!

  • @martinduong6944
    @martinduong6944 2 года назад

    It's amazing tutorial.

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

    Nice video, is there a way to do that using Fastify instead od Express?

  • @johndev-k3o
    @johndev-k3o Месяц назад

    why is there no response on the postman?

  • @shubham8550
    @shubham8550 2 года назад

    great content 😊👍

  • @hoseinmirian
    @hoseinmirian 2 года назад

    thanks amazing video. dont u have a course for this on udemi or somewhere? second, the concept of microservice is to have each service based on one language if team wants, and the way nest js works seems its fit for whole communication through js files? third!, Its a bit confusing when u are sending any type of request to the same root route like localhost:3000. whilst having route for each service might makes more sense what do u think? I mean u are sending all type of request to it and it dispatch events! fine! but there is no actual route so front-end can call in different end point.. can u clarify on that, tnx

  • @carlosspark2756
    @carlosspark2756 2 года назад

    Hi great content , would you show a server-frontend mvc architecture using nest-next npm package

  • @mkroven
    @mkroven 2 года назад

    thank you this is a great tutorial.

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

    Hi, I'm currently on nest@9.x.x and kafka@2.x.x and had to call the toString() prototype method on the ClientKafka emit() method.
    The NestJs documentation needs update.

  • @yatindrajain6828
    @yatindrajain6828 2 года назад

    Hi, Is there any way to get messages based on offset or get offset of last consumed message?

  • @wayneyu3031
    @wayneyu3031 2 года назад

    How can I set up the VS Code theme as yours, can u give me so reference? Again, I love your video so much, great work, looks cool! keep going bro!

    • @mguay
      @mguay  2 года назад

      Thanks! I use Material Theme + Icons which are extensions.

  • @abdullahajibade7210
    @abdullahajibade7210 2 года назад

    Does the event pattern has a return type as message pattern. I asked because of the subscription you did.

    • @mguay
      @mguay  2 года назад

      It returns an Observable the same as the message pattern, however I'm not sure what data would come back, if any.

  • @xisssss
    @xisssss 2 года назад

    great tutorial! really sorry for the stupid question.. but what vscode theme are you using?

    • @mguay
      @mguay  2 года назад +1

      No such thing. I’m using Material theme and icons.

  • @farzadthev1554
    @farzadthev1554 2 года назад

    Cool !!!
    Thanx a lot

  • @mridulmishra8166
    @mridulmishra8166 2 года назад

    -21deg Dude do u live in siberia ? :p ... great content BTW.

    • @mguay
      @mguay  2 года назад +1

      I'm in the USA.

  • @michaelmontero2902
    @michaelmontero2902 2 года назад

    amazing.

  • @MartinPerez-mi1ty
    @MartinPerez-mi1ty 2 года назад

    New sub

  • @samereldadah1911
    @samereldadah1911 2 года назад

    Great

  • @Abhishekn._
    @Abhishekn._ Год назад

    thanks

  • @misternether8602
    @misternether8602 6 месяцев назад

    Nice tutorial, but too much code in one place, making it hard to comprehend

  • @marcovignotto1559
    @marcovignotto1559 2 года назад

    Thanks! I literally love your content! But you're too fast, I think in 5 minutes I paused 100 times!

    • @mguay
      @mguay  2 года назад

      Thanks! And I appreciate the feedback.