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_”前缀。