use*_*584 2 events rabbitmq node.js microservices nestjs
我有一些微服务,通过API网关公开。网关负责处理身份验证和路由到系统中。网关后面的服务主要是简单的CRUD服务。每个服务都公开自己的API,并通过HTTP同步通信。所有这些服务,包括API-Gateway,都是“默认” NestJS应用程序。
让我们继续坚持猫的例子。每当Cat-Service更新或创建新的时Cat,我都希望CatCreatedEvent或被CatUpdatedEvent模仿。该事件应被推送到某些消息代理中,例如RabbitMQ,而另一个服务应侦听此事件并异步处理该事件。
我不知道如何以正确的方式“注入” RabbitMQ来实现这一目标,我想知道这种方法是否合乎常理。我已经看到了NestJS的CQRS模块,但是我认为CQRS对于该域来说有点过多。尤其是因为在此域中没有好处,无法拆分读写模型。也许我完全走错了道路,所以希望您能给我一些建议。
nestjs作为微服务支持RabbitMQ。如果您希望您的应用程序同时支持http请求和消息代理,则可以创建一个混合应用程序。
// Create your regular nest application.
const app = await NestFactory.create(ApplicationModule);
// Then combine it with a RabbitMQ microservice
const microservice = app.connectMicroservice({
transport: Transport.RMQ,
options: {
urls: [`amqp://localhost:5672`],
queue: 'my_queue',
queueOptions: { durable: false },
},
});
await app.startAllMicroservicesAsync();
await app.listen(3001);
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
2334 次 |
| 最近记录: |