IT源码网

node.js之发布-订阅设计模式

lyhabc 2024年02月03日 程序员 19 0

我有两个项目:其中一个是多处理器项目,第二个是单处理器项目。它们都是用 Node JS 编写的。

此外,我正在使用三个系统 - 它们是: Loggly、Mixpanel、电子邮件系统。 有一些事件与这两个项目相关 - 例如某些产品的交易。

一旦交易事件发生 - 我需要做三件主要的事情: 1) 更新 Loggly 有关事务属性的信息。 2) 更新 Mixpanel 有关交易属性的信息。 3) 更新电子邮件系统(例如 - 发送有关交易的确认邮件)。

数据以JSON格式发送。

此外,有些事件与所有三个系统(Loggly、Mixpanel、eMail 系统)相关,有些事件仅与其中的一部分相关。

每个系统对数据的不同部分感兴趣。例如,某些系统需要所有数据,而其他系统仅使用事件数据的一小部分。

问题: 目前,在我的项目中,一旦事件发生,我就会将两个项目的数据直接发送到相关系统。这意味着我的代码在 2 个项目中重复(这很糟糕)。

例如:

  // call when transaction event happens 
    function foo(transactionData) { 
      Loggly.send('Transaction', transactionData); 
      Mixpanel.send('Transaction', transactionData); 
    } 

我正在寻找新的架构 - 它可以解决代码重复问题。 结合 Pub-Sub 模式和 AWS 工具的最佳架构是什么?

这样做的正确方法是什么?

感谢您的帮助。

请您参考如下方法:

由于您正在使用 AWS,我建议您详细了解 Amazon SNS https://aws.amazon.com/pub-sub-messaging/

您可以在 SNS 上设置一个“主题”,然后该主题会将消息散布到订阅该主题的任何服务。


评论关闭
IT源码网

微信公众号号:IT虾米 (左侧二维码扫一扫)欢迎添加!