- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
使用 nestjs 微服务,您可以发送消息和 接收 结果使用基于请求/响应的方法。这是通过 @MessagePattern
的组合实现的和 client.send('my_pattern', myData)
.有关示例,请参阅 nest 文档:https://docs.nestjs.com/microservices/basics#request-response和 https://docs.nestjs.com/microservices/basics#sending-messages .
如何在基于事件的方法中接收结果?
假设您有一个用户微服务和一个 auth 微服务。每当创建用户时,您还希望创建一个身份验证主题(保存用户名和密码的哈希值,以便用户可以使用 api 请求登录身份验证微服务而不是用户服务)。
auth/auth.controller.ts
@EventPattern('EVT_USER_CREATED')
public async handleUserCreated(data: any): Promise<AuthSubject> {
if (!data.username || !data.password) {
throw new RpcException('Auth subject must supply username and password');
}
const newSubject: CreateAuthSubject = {
username: data.username,
password: data.password,
email: data.email ?? '',
};
const sub = await this.subjectService.create(subject);
return sub;
}
用户/user.controller.ts
@Post('')
@ApiBody({ type: CreateUser })
@ApiCreatedResponse({ type: User })
public async create(@Body() user: CreateUser): Promise<User> {
const newUser = await this.userService.create(user);
this.userQueue
.emit<any, CreateUser>('EVT_USER_CREATED', user)
.subscribe((res) => {
console.log(res); // undefined
});
return newUser;
}
为了验证我的设置没有错误,我更改了
@EventPattern
至
@MessagePattern
和
this.userQueue.emit<...
至
this.userQueue.send<...
.它起作用了,即 res 是一个有效的身份验证主题,具有预期的用户名和密码。但是,使用此问题中概述的基于事件的方法
res
是
总是
undefined
(无论身份验证 Controller
handleUserCreated
是否返回或抛出)。
@EventPattern('EVT_USER_CREATED') public async handleUserCreated
方法到其 Controller 。可观察的
this.userQueue.emit<any, CreateUser>('EVT_USER_CREATED', user)
然后将收到两个结果:每个微服务消费用户创建的事件一次。
@EventPattern('EVT_USER_CREATED')
public async handleUserCreated(data: any): Promise<AuthSubject> {
const customer = await this.customerService.create(data);
return customer ;
}
现在通过上述设置,微服务认证和客户将交替接收事件:如果用户微服务发出用户的创建,只有认证服务会对其作出 react 并从帽子用户创建认证主题。不会为该用户创建客户。对于在用户微服务中创建的下一个用户,只会创建一个客户,但不会创建身份验证主题。第三个创建的用户将再次被 auth 微服务消费,但不会被客户微服务消费。等等。
-- auth microservice
/
user microservice --- message broker ---
\
-- customer microservice
总结一下:我如何实现图中所示的消息传递架构,这样我只需要一个
emit(...)
调用
user.controller.ts
并且,这样我在对
emit(...)
的订阅中重新获得了两个回复。称呼?
最佳答案
可能有点晚了,但我为 future 的用户留下了我的贡献。
对于这种强基于事件的架构,建议使用Kafka这样的消息代理,不同的服务可以订阅不同的主题,甚至不同的服务也可以监听同一个主题,这样你就可以使用react以不同的方式处理同一个事件。
Kafka 还提供了许多优势,当您想扩展微服务时将非常有用,此外,它还支持 Nest。
https://docs.nestjs.com/microservices/kafka
您应该记住的是,在使用消息传递系统时,通信通常是完全异步的,这是一个重要的细节,因为按照您提供的案例,不仅足以让您通过 kafka 将消息发送到另一个微服务以验证用户的凭据,但有必要向客户端返回响应。对于这种情况,nest 提供的工具是有限的,因为使用 @MessagePattern 装饰器,我们可以在 Controller 中接收来自 kafka 的消息,但我们不能等待响应(同一主题或其他主题)并确认成功响应到客户要求。在这种情况下,您可以方便地使用 Kafkajs ( https://kafka.js.org/ ) 创建自己的传输器或自己的 kafka 客户端,以便在必要时保留用户的请求,直到收到另一个主题的确认。
我在某些论坛中看到的一个解决方案是将一个对象保存在内存中(键/值),其中包含与用户 ID 关联的请求的“响应”对象,这样您就可以通过 kafka 或任何方式发送消息具有特定操作的其他代理,并接收另一个 Controller 的确认,检索用户的“请求”对象,然后发送响应(Request.send(...))。这不是理想的解决方案,但它适用于某些情况。
例如:
@Controller('users')
class MyController {
constructor(private kafkaClient: KafkaClient) {}
private users: new Map<string, Request>() // Or private users: any = {}
onModuleInit() {
// By default, NestJs create topic "users-topic.reply"
this.kafkaClient.subscribeToResponseOf('users-topic')
}
@Post('auth')
authUser(@Req req: Request, @Res res: Response): void {
const userData = req.body;
const { id } = userData;
// Save request object in private variable;
this.users.set(id, res); // or this.users[id] = res;
// Send kafka message to validate user data
this.kafkaClient.emit('users-topic')
}
@MessagePattern('users-topic.reply')
authUser(@Payload() data: any): any {
if (data.message === 'success') {
const res:Request = this.users.get(data.id); // or this.users[data.id];
// Clean users object
this.users.remove(data.id); // or this.users[data.id] = null;
// Response client request
res.send('Authentication successfully')
}
}
}
关于microservices - 带有 1 个生产者和 2 个消费者的 Nestjs 基于事件的消息传递,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62497661/
我正在尝试将 WPF CodeBehid 事件(如 Event、Handler、EventSetter)转换为 MVVM 模式。我不允许使用 System.Windows.Controls,因为我使用
我可能误解了 Backbone 中的事件系统,但是当我尝试以下代码时什么也没有发生。当我向 Backbone.Events 扩展对象添加新属性时,它不应该触发某种更改、更新或重置事件吗?就像模型一样吗
我遇到了一个简单的问题,就是无法弄清楚为什么它不起作用。我有一个子组件“app-buttons”,其中我有一个输入字段,我想听,所以我可以根据输入值过滤列表。 如果我将输入放在我有列表的根组件中,一切
System.Timers.Timer 的 Elapsed 事件实际上与 System.Windows.Forms.Timer 的 Tick 事件相同吗? 在特定情况下使用其中一种比使用另一种有优势吗
嗨,这个 javascript 代码段是什么意思。(evt) 部分是如此令人困惑.. evt 不是 bool 值。这个怎么运作? function checkIt(evt) { evt
我正在使用jquery full calendar我试图在事件被删除时保存它。 $('calendar').fullCalendar ({
我有两个链接的鼠标事件: $('body > form').on("mousedown", function(e){ //Do stuff }).on("mouseup", function(
这是我的代码: $( '#Example' ).on( "keypress", function( keyEvent ) { if ( keyEvent.which != 44 ) {
我尝试了 dragOver 事件处理程序,但它没有正常工作。 我正在研究钢琴,我希望能够弹奏音符,即使那个键上没有发生鼠标按下。 是否有事件处理程序? 下面是我正在制作的钢琴的图片。 最佳答案 您应该
当悬停在相邻文本上时,我需要使隐藏按钮可见。这是通过 onMouseEnter 和 onMouseLeave 事件完成的。但是当点击另外的文本时,我需要使按钮完全可见并停止 onMouseLeave
我有ul标签内 div标签。我申请了mouseup事件 div标记和 click事件 ul标签。 问题 每当我点击 ul标签,然后都是 mouseup和 click事件被触发。 我想要的是当我点击 u
我是 Javascript 和 jQuery 的新手,所以我有一个非常愚蠢的疑问,请耐心等待 $(document).click(function () { alert("!"); v
我有一个邮政编码解析器,我正在使用 keyup 事件处理程序来跟踪输入长度何时达到 5,然后查询服务器以解析邮政编码。但是我想防止脚本被不必要地调用,所以我想知道是否有一种方法可以跟踪 keydown
使用事件 API,我有以下代码来发布带有事件照片的事件 $facebook = new Facebook(array( "appId" => "XXX", "se
首次加载 Microsoft Word 时,既不会触发 NewDocument 事件也不会触发 DocumentOpen 事件。当 Word 实例已打开并打开新文档或现有文档时,这些事件会正常触发。
我发现了很多相关问题(这里和其他地方),但还没有具体找到这个问题。 我正在尝试监听箭头键 (37-40) 的按键事件,但是当以特定顺序使用箭头键时,后续箭头不会生成“按键”事件。 例子: http:/
给定的 HTML: 和 JavaScript 的: var $test = $('#test'); $test.on('keydown', function(event) { if (eve
我是 Node.js 的新手,希望使用流运行程序。对于其他程序,我必须同时启动一个服务器(mongodb、redis 等),但我不知道我是否应该用这个运行一个服务器。请让我知道我哪里出了问题以及如何纠
我正在尝试使用 Swift 和 Cocoa 创建一个适用于 OS X 的应用程序。我希望应用程序能够响应关键事件,而不将焦点放在文本字段上/文本字段中。我在 Xcode 中创建了一个带有 Storyb
我有以下代码: (function(w,d,s,l,i){ w[l]=w[l]||[];w[l].push({
我是一名优秀的程序员,十分优秀!