RocketMQ相关问题
1、发送消息时tags参数疑惑
tags参数:在发送消息是,新建Message对象时,可以指定要发送到那个topic下。我的疑惑是:发送消息时,这个tags参数到底是指定一个还是可以指定多个。
先查看订阅消息方法源码:
1 /** 2 * Subscribe a topic to consuming subscription. 3 * 4 * @param topic topic to subscribe. 5 * @param subExpression subscription expression.it only support or operation such as "tag1 || tag2 || tag3" <br> 6 * if null or * expression,meaning subscribe all 7 * @throws MQClientException if there is any client error. 8 */ 9 @Override 10 public void subscribe(String topic, String subExpression) throws MQClientException { 11 this.defaultMQPushConsumerImpl.subscribe(topic, subExpression); 12 }
注意到,第二个参数是指定订阅topic下的哪些tag,多个tag之间用||分隔。
基于以上的经验,我们首先在生产者发送消息的时候将Message的tags参数设置为两个,用||分隔,如TagA||TagB,意思是将一条消息发送到两个tag下(一条消息应该只属于一个tag,这里且先做测试):
1 /* 2 * Create a message instance, specifying topic, tag and message body. 3 */ 4 Message msg = new Message("TopicTest" /* Topic */, 5 "TagA||TagB" /* Tag */, 6 ("Hello RocketMQ " + i).getBytes(RemotingHelper.DEFAULT_CHARSET) /* Message body */ 7 );
这里大家可以先注意一下这个都提到的是tag,而不是tags。
按照上面的想法,既然生产者把一条消息发到了两个tag下面,那我们就分别订阅TagA和TagB,收到消息后打印该消息的标签属性:
1
consumer.subscribe("TopicTest", "TagA");
//consumer.subscribe("TopicTest", "TagB");
//consumer.subscribe("TopicTest", "TagA||TagB");
@Override 2 public ConsumeConcurrentlyStatus consumeMessage(List<MessageExt> msgs, 3 ConsumeConcurrentlyContext context) { 4 System.out.println(msgs.get(0).getTags()); 6 return ConsumeConcurrentlyStatus.CONSUME_SUCCESS; 7 }
经过测试,分别订阅TagA和TagB时都收不到消息,只有订阅了TagA||TagB时才能收到消息,且消息标签就是TagA||TagB
2、总结
以上说明发送消息时指定Message参数tags时,试图用||分隔开传递多个tag,rocketmq并不会解析将其拆成多个tag,而是将其整体当作一个tag,也就是说,一条消息只能属于一个tag。
!!!!!!!!!
但是我想说为什么源码的Message类的形参列表要用tags这种复数形式呢?咋不用tag,而且
public String getTags() {//获取消息标签 return this.getProperty(MessageConst.PROPERTY_TAGS); }
为什么这里都是tags这种复数形式。。。这很容易让我这种多想的人觉得纳闷,如果只能指定一个标签就用tag不就行了,为毛要用tags。