rocketmq中的自定义消息头

在springboot中使用rocketmq的客户端,有2种方式。

一是使用 org.apache.rocketmq的rocketmq-client

二是,在pom.xml中引用

<dependency>
<groupId>org.apache.rocketmq</groupId>
<artifactId>rocketmq-spring-boot-starter</artifactId>
<version>2.0.3</version>
</dependency>

具体网址 https://github.com/apache/rocketmq-spring/blob/master/README_zh_CN.md

在原文的FAQ的6和7中的描述,即可以添加自定义的头属性。

在实验中发现,与原有定义的属性名称重复的自定义名称将按照描述中的说明添加“USER_”,如果不是冲突的名称,则不会被改变。

public void send() throws InterruptedException {
        Message<?> msg = MessageBuilder.withPayload("Hi rocketmq!")
                .setHeader(MessageConst.PROPERTY_KEYS, "20191018")
                .setHeader("TAGS", "191018")
                .setHeader(MessageConst.PROPERTY_BUYER_ID,"20191018a")
                .setHeader("MQ", "user_mq")
                .build();
        template.convertAndSend(topic + ":1018", "topic with tags");
        java.lang.Thread.sleep(2000);
        template.send(topic, msg);
        log.info("send mq message, ext message" + msg.toString());
    }
setHeader("TAGS", "191018"),将被过滤掉,setHeader("USER_TAGS", "191018"),在接收端能收到结果的。
想添加tags属性应该只能放在发送函数中的第一个参数中。如代码中的 ‘(topic + ":1018",’
setHeader(MessageConst.PROPERTY_KEYS, "20191018"),是有效的。
比如 MessageConst.PROPERTY_BUYER_ID 这样的 MessageConst下的其他属性(试过几个)似乎都被过滤了。并不像是描述中说的那样添加 “USER_”前缀。
 
posted @ 2019-10-20 17:43  蓝色牧客  阅读(4133)  评论(0编辑  收藏  举报