当前位置: 首页 > 知识库问答 >
问题:

谷歌云发布订阅相同消息的多个订阅者

贺运良
2023-03-14

我正在使用GCP发布/订阅实现事件驱动。

我有一个名为orders的主题,该主题将有一个名称为orderPlacedSubscription的订阅。我有两个服务,它们希望侦听此订阅的所有消息并执行不同的操作,因此我有paymentService和notificationService,paymentService将侦听由orderPlacedSubscription过滤的每个消息,并处理付款,通知服务将侦听相同的消息并发送通知。

    < li >发布-订阅是否支持两个订阅者与一个订阅相关,并且都接收消息并分别确认它们? < li >如果每个订阅者可以单独确认消息而不影响其他订阅者,google cloud发布-订阅是否支持在一个订阅者失败的情况下为不同的订阅者重试?

共有1个答案

蓬思博
2023-03-14

是的,订阅可以有多个订户客户端。

在订阅工作流中,如果订阅者未确认消息,Pub/Sub 将尝试重新传递未完成的消息。在重新传递未完成消息的过程中,Pub/Sub 会保留并尽量不将未完成消息传递给同一订阅上的任何其他订阅者。确认未完成的消息后,可以将其传递给其他订阅者。

您可以参考订阅工作流和此留档以获取更多信息。

 类似资料:
  • 我是新的数据流和发布子工具在GCP。 需要将prem过程中的电流迁移到GCP。 当前流程如下: 我们有两种类型的数据馈送 Full Feed–其adhoc作业–完整XML的大小约为100GB(单个XML–非常复杂的一个–完整的数据–ETL作业处理此XML并将其加载到约60个表中) 单独的ETL作业用于处理完整提要。ETL作业过程完全馈送并创建负载就绪文件,所有表将被截断并重新加载 源系统每30分钟

  • 提供的检索/更新API是否有任何限制? 我找到了这些文件: https://cloud.google.com/pubsub/quotas:包含有关吞吐量的信息以及主题、订阅和消息创建数量的限制 检索/更新API的限制呢? 例如:检索具有名称的主题,更新订阅。

  • 微信文档:https://developers.weixin.qq.com/miniprogram/dev/api-backend/open-api/subscribe-message/subscribeMessage.addTemplate.html 组合模板并添加至帐号下的个人模板库 $tid = 563; // 模板标题 id,可通过接口获取,也可登录小程序后台查看获取 $kidLi

  • 开普勒消息目前分为三大类:公告,告警和通知。 通知中根据不同的操作事件类型,分为十几个事件。每个事件都跟项目操作相关。便于接收项目操作变更的通知。 分类 事件 公告 Alarm 告警 Proclaim 通知 Build,Apply,Audit,Delete,Rollback,Logging,Reboot,Command,Storage,Extend... 订阅界面: 用户中心,点击头像,下拉菜单→

  • 我正在寻找一种完全从代码创建发布/订阅主题的方法。我设法用域验证api验证域,但我找不到向项目注册域的api。这里描述的唯一方法https://cloud.google.com/pubsub/advanced#register与控制台的交互使用。

  • 简介 Redis 的列表类型键可以用来实现队列,并且支持阻塞式读取,所以 Redis 能够非常容易的实现一个高性能的优先队列。同时在更高层面上,Redis 还支持“发布/订阅”的消息模式,可以基于此构建一个聊天系统。 发布示例 发布(Publish)即将消息发布到频道中。示例代码: // 发送消息 Redis::publish('chan-1', 'Hello, World!'); // 发送消息

  • 主要内容:发布/订阅流程,常用命令汇总,基本命令应用Redis PubSub 模块又称发布订阅者模式,是一种消息传递系统,实现了消息多播功能。发布者(即发送方)发送消息,订阅者(即接收方)接收消息,而用来传递消息的链路则被称为  channel。在 Redis 中,一个客户端可以订阅任意数量的 channel(可译为频道)。 消息多播:生产者生产一次消息,中间件负责将消息复制到多个消息队列中,每个消息队列由相应的消费组进行消费,这是分布式系统常用的

  • 发布/订阅 消息顺序 当使用 pub/sub API的时候,你需要做一个决定:那就是对于来自同一个连接的消息是应该按顺序处理还是应该并行处理。 按顺序处理意味着你不需要关心线程安全,并且保持了事件的顺序;消息会以完全相同的顺序接收处理(通过队列),因此,这意味着消息能够被相互延迟。 另外一种选择是并发处理。使用并发处理 不能保证 工作处理的有序性,并且你的代码要对并行消息完全负责确保它不会破坏内部