• RocketMQ相关问题


    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。

  • 相关阅读:
    商品销量与虚拟销量的计算方法
    EF获取当天的数据集合
    C# xml转化为类集合
    Linux下找不到动态链接库;
    STRTOK函数和STRTOK_R函数
    Ubuntu Linux 环境变量PATH设置
    关于Ubantu下使用cshell的问题解决
    realloc 使用详解(分析realloc invalid pointer、指针无效等错误)【转】
    ubuntu安装包查找及安装
    【转】MySql数据库--mysql_real_escape_string()函数
  • 原文地址:https://www.cnblogs.com/xuxiaojian/p/9052020.html
Copyright © 2020-2023  润新知