Wow. This dude is just giving away thousands of dollars worth education for free. Salute to you sir. You are helping many. I wish all the success in your career.
I am watching you videos and this video specifically it is really great to have such content. Because there is almost no one on the internet who is helping with Microservices with NestJS. Thank you for the content from all of us. I am sure many people will take help from this video.
Wow, this was the missing piece for me to start using microservices pattern. The puzzle is almost completed (just waiting for deployment part) :) Thank you, Sir.
Hello Michael, I would like to thank you very much for this content, it is very rich in detail and helped me a lot to understand a little more about microservices and also monorepo with NestJS. You've gained another subscriber. Congratulations on a job well done.
Thanks! Tutorial straight to the point. In my case I came across the problem, have you dealt with this error? "There is no matching message handler defined in the remote service."
Awesome content! Really well explained and it's insane how every time I watch some NestJS content I learn a new way of doing the same thing. This bad boy is actually quite flexible for a framework. Do you plan on doing a video where you e2e test an application? One of your videos on unit testing really helped me on work 🙏🏽
Hi Michael, May I know why both on Auth and Billing service you define the app.connectMicroservice functionality but in Order service you didn't define the connectMicroservice instead you call the RmqModule.register which calls the ClientsModule.register, is there a rule for this one? because I thought when we want to define our service as microservice we need to call the connectMicroservice for each services? sorry im new to microservice and nestJS.
Nice video and great content , Can you make a enterprise level application using NestJS with micro-service architecture in which you cover e2e testing , caching, queue management system etc. which required to make production level application using micro-services architecture.
If we use one api-gateway app here and RabbitMQ will connect with others microservices via api-gateway only then how it will be? is that will be good ?
Great content. Michael Guay, on the auth service, why is it that instead of validation I do get always a 401 Unauthorized? Is there a way of working around this?
Hi, at 1:11:05 in ordering apps auth section, I don't understood why are you inject(AUTH_SERVICE) constante which is a string value as injector for clientProxy. How works this and in what way does this constant refer to this service ?
Hey guys please i have an error. I followed all the steps till 28:02 but i got : | [Nest] 44 - 07/21/2022, 1:41:51 PM ERROR [MongooseModule] Unable to connect to the database. Retrying (1)...
@@mguay first of all, THANKS for this amazing tutorial.! I think the issue is about that the image with replicas set that you use here, is not compatible with Mac M1 still..
Thanks for the awesome video Michael. I was wondering how it is possible to connect to 2 databases from one of the microservice and second microservice connects to only second database and both are responsible for read/write operations in that database. I know there can be microservice communication used but if we wan to avoid the delay.
Thank you sir for everything you're doing for us, but could you please tell me why you have followed the one shared db approach for all microservices you have implemented? The one db per each microservice could be more suitable for microservices architecture.
Excellent tutorial! This works out-of-the-box from your Repo on a Mac with an Intel Processor, as expected, but I've been trying to update the Images for the Apple M1 ARM64 Arch. Have you tried this as well and, if so, would you mind sharing updated docker-compose / Dockerfile(s)?
The way you explained is really awesome and helpfull. I have some confusions : Why do we need to create two JwtAuthGuard and how you are deciding where to use JwtAuthGuard and flow of its execution?
Great tutorial, thanks. Why using MessagePattern and switch to rpc? In Auth microservice the rmq auth queue is connected, isn't that mean that we can use EventPattern in auth controller?
@Michael, thank you for the great tutorial. I have a quick question regarding deployment. You see... the Billing service doesn't listen to any port. With this setup, how do I go about health-checking the service container within AWS ECS? The easiest option that I came to my mind is making it hybrid app just like the Auth service to be able to make a HTTP call to the container via the port. What else option do I have?
Nice video Michael but I suggest to use any diagram for more simplification before starting that will make it very easy and will get new ideas from comments sure
really good tutorial, thank you for creating this video bay the way, sometimes when creating an app we also need the second auth for admin, regarding with auth guard, what is the best practice you advise for this case?
@Michael Guay hey, do you have any course about nestjs with microservices from scratch? or another option, what is the best approach to learn nest js and microservices? i know express, and i know the concept of microservices, but i did not understand what is nestjs and nestjs microservices . thanks
Maybe someone had this issue: 28:30 npm ERR! path /usr/src/app appears right after I restart the container. And I need to restart it because, even though I followed this tutorial 3 separate days from the beginning, the docker is not restarting when I make updates and click save.
Great content. Thank you. I have a small doubt regarding registering the RmqModule. You have registered it in order module import. However If I want to use it in another module should I register again? Or is there anyway I can register it to a common module and import that module everywhere else in my code. For example emailQueue is something that I might require in multiple modules (order, billing and auth). Can you suggest me a generic way to register EMAIL_SERVICE (emailQueue) in all the modules please?
Why I can't connect mongodb replicaset in my Macbook M1. Error throwing like this [Nest] 69 - 10/24/2023, 10:35:24 AM ERROR [MongooseModule] Unable to connect to the database. Retrying (1)...
How would I go about enabling HMR for the individual microservices? I am able to do it for regular NestJS app setup, but with this shared libraries approach, I am not able to figure it out unfortunately.
How does my application consume multiple queues. I saw an approach someone suggested on stackoverflow where you repeat the "app.connectMicroservice" for each queues, is there a cleaner approach ?
Wonderful video mate! Helped a lot to understand the system and I would like to give a feedback. Can you make commits as you make progress? For example we have "docker", "microservices" and "billing app" chapters on youtube, wouldn't be good if you make commits for each youtube chapter?
May I ask a question Monorepos can't be deployed seperately, so why is this still considered as microservices? It's more monolithic app structure I guess Thanks!
well explained, learned a lot, liked the way you make use of the common library for rmq and mongo I'm having a bit of trouble connecting to my mongodb when using compass, can I simply connect on localhost:27017 with root:password123 ? or is it different with the way it's set up in your video?
Wow. This dude is just giving away thousands of dollars worth education for free.
Salute to you sir. You are helping many.
I wish all the success in your career.
Really helped me get up and running quickly with NestJS Microservices and RabbitMQ, thank you! Grab beer or two on me!
Thank you so much!
The best course about NestJS Microservices
This content is unique, it helps us understand, something very complicated into something simple.
Great tutorial!
I am watching you videos and this video specifically it is really great to have such content. Because there is almost no one on the internet who is helping with Microservices with NestJS. Thank you for the content from all of us. I am sure many people will take help from this video.
Wow, this was the missing piece for me to start using microservices pattern. The puzzle is almost completed (just waiting for deployment part) :)
Thank you, Sir.
Thanks so much for the tutorial and the source code, it is much help to understand the concept
Thank you for your support!
Best nestjs channel out there.
Hello Michael, I would like to thank you very much for this content, it is very rich in detail and helped me a lot to understand a little more about microservices and also monorepo with NestJS. You've gained another subscriber. Congratulations on a job well done.
This tutorial makes microservice implementation looks so simple. Thanks coder!
Awesome! Thanks for the great content, waiting for the deployment part!! ♥ Thx Bro.
It was an excellent explanation. Ton of things, we can learn. Just waiting for deployment part
Awesome quality content. No BS.
Minute 5:46, I am loving this tutorial, thanks!
You're the best. waiting for the deployment part
exactly 👍
Such an amazing video. Really helped me learn and build my own custom project. Much Thanks. Looking forward for more nestjs content
Awesome! Looking foward to the deployment video!
Every one of your video helps me so much, thanks for doing this!
Thanks man, it's really comprehensive. I learnt a lot from it
Thank you very much! Viewer from Taiwan.
You are very good at teaching. Keep it up.
hey, you have dropped this ... 👑
excellent tutorial ... great content in such a short time
This is awesome, man. Has been very helpful to me
OMG!! Our Best Teacher Are Back🥰
Appreciate the support!
absolute gold, thank you man
The course that i waiting for, Thank you so much sir!
litterlay a gold mine . nothing else to say 😘😘
your tutorial is pretty awesome, very well structured
Thank you so much for the great tutorial!
Just a heads up for anyone using Macbook M1 with the ARM64 chip, Bitnami doesn't support it yet.
Yeah ;(
This content is amazing, Thank you very much, is the best content ever!
damn, I learn so many things in one video, thanks, bro.
You are amazing! Thank you very much for such great content!
Thank you for sharing awesome source code.
+1000 loved your content and looking forward for your next video. Thank you and best of luck
Really Appreciated , thanks for this great tuts. helps a lot.
Many thanks, great tutorial!
Thank you! Really useful tutorial.
Very helpful tutorial. Thank you so much.
Thx for great content, i learn alot from this video!)
Awesome work !!,
Keep it up !!
Thanks! Tutorial straight to the point.
In my case I came across the problem, have you dealt with this error? "There is no matching message handler defined in the remote service."
I got issues with MongooseModule, it says it can’t connect to mongodb-primary 😢
You are the best,thanks!!!
Get my highly rated NestJS Microservices Course at a discount: michaelguay.dev/udemy
Thank you! I bought your course!
thank youuu.... for the tutorial😁
thanks so much for this video, i love it
Great content 🙏🏻
You are the best!! 😍
Awesome content! Really well explained and it's insane how every time I watch some NestJS content I learn a new way of doing the same thing. This bad boy is actually quite flexible for a framework. Do you plan on doing a video where you e2e test an application? One of your videos on unit testing really helped me on work 🙏🏽
Thank you! I have a video on E2E testing here: ruclips.net/video/R2ndY_JhxWk/видео.html
Hey Michael, thanks for the tutorial, super educative! Do you plan to do a tutorial for authorization in NestJS?
Thanks! I have a video on this, check out my channel.
Hello, two questions:
Why billing service doesn't have a port defined?
Shouldn't we have a separate database for each service?
I wonder the same
you don't need to define port in billing app because the app is not listen on the http or tcp. It''s listening to the Rmq
Hi Michael,
May I know why both on Auth and Billing service you define the app.connectMicroservice functionality but in Order service you didn't define the connectMicroservice instead you call the RmqModule.register which calls the ClientsModule.register, is there a rule for this one? because I thought when we want to define our service as microservice we need to call the connectMicroservice for each services? sorry im new to microservice and nestJS.
the order service serves as the entry point into the application. Therefore you need to instantiate Rabbit MQ from there.
Nice video and great content , Can you make a enterprise level application using NestJS with micro-service architecture in which you cover e2e testing , caching, queue management system etc. which required to make production level application using micro-services architecture.
Hot reload not working on docker-compose with the NestJS 10. I couldn't fix it. Can you help me?
yes me too still facing same issue😢
The Best. Thanks
If we use one api-gateway app here and RabbitMQ will connect with others microservices via api-gateway only then how it will be? is that will be good ?
Great content. Michael Guay, on the auth service, why is it that instead of validation I do get always a 401 Unauthorized? Is there a way of working around this?
Hi, at 1:11:05 in ordering apps auth section, I don't understood why are you inject(AUTH_SERVICE) constante which is a string value as injector for clientProxy. How works this and in what way does this constant refer to this service ?
Hey guys please i have an error. I followed all the steps till 28:02 but i got : | [Nest] 44 - 07/21/2022, 1:41:51 PM ERROR [MongooseModule] Unable to connect to the database. Retrying (1)...
Same here! Does anybody solved it?
Do you see Mongo start up properly?
@@mguay first of all, THANKS for this amazing tutorial.!
I think the issue is about that the image with replicas set that you use here, is not compatible with Mac M1 still..
try to change the mongodb version, it should work fine...
This works:
MONGO_URI=mongodb://root:password123@localhost:27017/?authMechanism=DEFAULT&directConnection=true
Very cool 👍 graphql federation with microservices maybe in future ?
Thanks for the awesome video Michael. I was wondering how it is possible to connect to 2 databases from one of the microservice and second microservice connects to only second database and both are responsible for read/write operations in that database. I know there can be microservice communication used but if we wan to avoid the delay.
Thank you sir for everything you're doing for us, but could you please tell me why you have followed the one shared db approach for all microservices you have implemented? The one db per each microservice could be more suitable for microservices architecture.
Super interesting topics
Excellent tutorial! This works out-of-the-box from your Repo on a Mac with an Intel Processor, as expected, but I've been trying to update the Images for the Apple M1 ARM64 Arch. Have you tried this as well and, if so, would you mind sharing updated docker-compose / Dockerfile(s)?
Is it a good experience to have gateway apps as well?
great tutorial
The way you explained is really awesome and helpfull. I have some confusions : Why do we need to create two JwtAuthGuard and how you are deciding where to use JwtAuthGuard and flow of its execution?
I got issues with MongooseModule, it says it can’t connect to mongodb-primary. Please resolve. @Michael
Did you create an APi gateway?
Great tutorial, thanks. Why using MessagePattern and switch to rpc? In Auth microservice the rmq auth queue is connected, isn't that mean that we can use EventPattern in auth controller?
@Michael, thank you for the great tutorial. I have a quick question regarding deployment. You see... the Billing service doesn't listen to any port. With this setup, how do I go about health-checking the service container within AWS ECS? The easiest option that I came to my mind is making it hybrid app just like the Auth service to be able to make a HTTP call to the container via the port. What else option do I have?
Really nice, were you able to connect into mongo atlas? I can't and it would be great to see data into database
Nice video Michael but I suggest to use any diagram for more simplification before starting that will make it very easy and will get new ideas from comments sure
Great job.
really good tutorial, thank you for creating this video
bay the way, sometimes when creating an app we also need the second auth for admin, regarding with auth guard, what is the best practice you advise for this case?
I'm wondering if there or anywhere else a tutorial for doing database stuff like in this video but with typeorm and rdb?
Thank you much 👍👌🙌
How in this configuration work whis different queue in one client?
@Michael Guay hey, do you have any course about nestjs with microservices from scratch?
or another option, what is the best approach to learn nest js and microservices? i know express, and i know the concept of microservices, but i did not understand what is nestjs and nestjs microservices . thanks
Maybe someone had this issue:
28:30 npm ERR! path /usr/src/app appears right after I restart the container. And I need to restart it because, even though I followed this tutorial 3 separate days from the beginning, the docker is not restarting when I make updates and click save.
It was because docker can't run it WSL 2
Great content. Thank you. I have a small doubt regarding registering the RmqModule. You have registered it in order module import. However If I want to use it in another module should I register again? Or is there anyway I can register it to a common module and import that module everywhere else in my code. For example emailQueue is something that I might require in multiple modules (order, billing and auth). Can you suggest me a generic way to register EMAIL_SERVICE (emailQueue) in all the modules please?
@michael thanks. Can u throw some light on nestjs with saga topic? I am really confused with saga
Awesome!
Why I can't connect mongodb replicaset in my Macbook M1. Error throwing like this
[Nest] 69 - 10/24/2023, 10:35:24 AM ERROR [MongooseModule] Unable to connect to the database. Retrying (1)...
I cannot find the bitnami mongodb image repo seems it is no longer open sourced?
live reload isn't working on docker windows WSL. I don't know if anyone has a fix ?
same issue
same issue. i have search around but still can not solve
How would I go about enabling HMR for the individual microservices? I am able to do it for regular NestJS app setup, but with this shared libraries approach, I am not able to figure it out unfortunately.
thank you man
Hi. How to set username and passworf for RabbitMQ in connection options?
What about polyrepo .. is it a same way?
superb bro...
How does my application consume multiple queues. I saw an approach someone suggested on stackoverflow where you repeat the "app.connectMicroservice" for each queues, is there a cleaner approach ?
Wonderful video mate! Helped a lot to understand the system and I would like to give a feedback. Can you make commits as you make progress? For example we have "docker", "microservices" and "billing app" chapters on youtube, wouldn't be good if you make commits for each youtube chapter?
Hi Michael. I followed through the video however I want to deploy this on a service like Render. Could you help with this?
Hi! Thanks for the great tutorial... Is it possible to specify queue while emitting the event?
Wow 🤩
May I ask a question
Monorepos can't be deployed seperately, so why is this still considered as microservices?
It's more monolithic app structure I guess
Thanks!
well explained, learned a lot, liked the way you make use of the common library for rmq and mongo
I'm having a bit of trouble connecting to my mongodb when using compass, can I simply connect on localhost:27017 with root:password123 ? or is it different with the way it's set up in your video?
How do we ensure the transaction atomicity in case of any failure, such that the messages are not standing as orphan data in rabbitmq for processing?