tencent cloud

消息队列 Pulsar 版

动态与公告
新功能发布记录
集群版本更新记录
产品公告
产品简介
TDMQ 产品系列介绍与选型
什么是消息队列 Pulsar 版
产品优势
应用场景
技术原理
产品系列
开源 Pulsar 版本支持说明
与开源 Pulsar 对比
高可用
配额与限制
基础概念
产品计费
计费概述
价格说明
计费示例
续费说明
查看消费明细
欠费说明
退费说明
快速入门
入门流程指引
准备工作
使用 SDK 收发普通消息
使用 SDK 收发高级特性消息
用户指南
使用流程指引
配置账号权限
新建集群
配置命名空间
配置 Topic
连接集群
管理集群
查询消息及轨迹
跨地域复制
查看监控和配置告警
实践教程
客户端使用实践
异常消费者隔离
限流机制说明
交易对账
消息幂等性
消息压缩
迁移指南
单写多读集群迁移方案
虚拟集群平滑迁移至专业集群
API 参考
API 概览
SDK 参考
SDK 概述
SDK 配置参数推荐
TCP 协议(Pulsar 社区版)
安全与合规
权限管理
删除保护
云 API 审计
常见问题
监控相关
客户端相关
服务协议
服务等级协议
TDMQ 政策
联系我们
词汇表

使用 Shared 订阅模式消费消息

PDF
聚焦模式
字号
最后更新时间: 2025-12-24 15:18:52

操作背景

为了适用不同场景的需求,Pulsar 支持四种订阅模式:Exclusive、Shared、Failover、Key_Shared。
1. Exclusive 独占模式(默认模式):一个 Subscription 只能与一个 Consumer 关联,只有这个 Consumer 可以接收到 Topic 的全部消息,如果该 Consumer 出现故障了就会停止消费。
2. 共享模式(Shared):消息通过 Round Robin 轮询机制(也可以自定义)分发给不同的消费者,并且每个消息仅会被分发给一个消费者。当消费者断开连接,所有被发送给该消费者,但没有被确认的消息将被重新安排,分发给其它存活的消费者。
3. 灾备模式(Failover):当存在多个 Consumer 时,将会按字典顺序排序,第一个 Consumer 被初始化为唯一接收消息的消费者。当第一个 Consumer 断开时,所有的消息(未被确认和后续进入的)将会被分发给队列中的下一个 Consumer。
4. KEY 共享模式(Key_Shared):当存在多个 Consumer 时,将根据消息的 Key 进行分发,Key 相同的消息只会被分发到同一个消费者。
更多关于订阅模式的介绍请参考文档订阅模式
本文以官网提供的 Demo 为例,介绍共享模式(Shared)订阅模式功能与使用方式。

前提条件

pulsar 实例已开通公网访问或已购买云服务器
注意:
通过云服务上传 demo 的具体操作步骤详见 如何将本地文档上传到云服务器

操作步骤

步骤1. 在控制台新建 Pulsar 资源

1. 登录 TDMQ Pulsar 版控制台,创建一个集群和命名空间。
2. 在左侧导航栏选择 Topic 管理页签,当前集群和命名空间分别勾选创建好的集群和命名空间。
3. 单击新建,输入 Topic 名称和说明,其他选项可保持默认,单击保存,创建一个 Topic。

4. 单击操作列的新增订阅,为刚新建好的 Topic 创建两个订阅关系(Shared 订阅模式下只需要使用到其中一个订阅关系)。
5. 单击操作列的更多 > 查看订阅/消费者,可看到刚创建好的订阅。


步骤2. 下载 Demo 并配置相关参数

1. 下载官方 Demo 并解压。
2. 修改 Constant.java 参数。

参数
说明
SERVICE_URL
集群接入地址,可以在控制台集群管理页面查看并复制。

AUTHENTICATION
角色的密钥,角色密钥可以在角色管理中复制。


步骤3. 生产消息

1. 进入 /simple 目录下,修改 SimpleProducer.java 参数。

.topic:填写创建好的 Topic3 名称,需要填入完整路径,即 persistent://clusterid/namespace/Topic,clusterid/namespace/topic 的部分可以从控制台上 Topic 管理页面直接复制。

2. 编译并运行 SimpleProducer.java 程序发送消息。运行结果如下,可以看到生产者已经向 Topic 中生产了10条消息。


步骤4. 消费消息

1. 进入 /submodle 目录下,修改 SharedConsumer1.java 和 SharedConsumer2.java 程序参数。

.topic:填写创建好的 Topic 名称,需要填入完整路径,即 persistent://clusterid/namespace/Topic,clusterid/namespace/topic的部分可以从控制台上 Topic 管理页面直接复制。

.subscriptionName:填写 Topic 的订阅名称,可在 Topic 消费者界面查看。SharedConsumer1 中填写 sub1 订阅名称,SharedConsumer2 中也填写 sub1 订阅名称。

2. 编译并运行消息重试程序 SharedConsumer1.java 和 SharedConsumer2.java 。运行结果如下:




帮助和支持

本页内容是否解决了您的问题?

填写满意度调查问卷,共创更好文档体验。

文档反馈