我想制作一个包含多个通信流程的系统。
主过程正在引发事件。将有不同的事件,每个事件包含结构化数据。一些从属进程将订阅事件,接收数据并调用适当的处理程序。我的案子有两个考虑因素。
人们建议在这种情况下使用像Zero MQ这样的消息队列。我对它应该实现的方式有点困惑。据我所知,ZeroMQ只能发送\接收原始字符串数据。
我应该将数据打包到发布方的字符串(例如json或xml)中,在订阅方手动解压缩数据并仅过滤必要的消息吗?
如果有更好的方法来解决我的问题,我很高兴听到它。
我会为您描述的场景使用消息传递提供程序。我看到的优点是
1)不必编写代码来向订阅者传递消息。这让我专注于我的业务逻辑和数据格式。我可以决定数据格式(XML / JSON /任何适合我的要求且订阅者理解的格式)并发布消息。
2)如果出现需求,则可以在不添加/修改任何代码的情况下增加订户数量。
3)订户可以移动到不同的机器而不会影响解决方案。
4)订阅者也可以脱机,主/发布者仍然可以发布消息。订阅者可以稍后进入并调用所需的处理程序。
这些是我看到的选项: