/spring-boot-rocketmq-starter

Spring Boot Starter for Apache RocketMQ

Primary LanguageJavaApache License 2.0Apache-2.0

Spring Boot RocketMQ Starter

Build Status Coverage Status Maven Central License

Open Source Spring Boot Starter for Apache RocketMQ, develop with RocketMQ easily.

中文版

Quick Start

Maven Dependency

    <dependency>
        <groupId>io.github.rhwayfun</groupId>
        <artifactId>spring-boot-rocketmq-starter</artifactId>
        <version>0.0.3.RELEASE</version>
    </dependency>

Configuration

You just need to add a few configurations on application.properties, configurations are like as follows:

# Apache RocketMQ
spring.rocketmq.nameServer=localhost:9876
spring.rocketmq.producer-group-name=spring-boot-test-producer-group

Look, it's easy, but in the real environment, you need modify above configurations.

Consume message

For consume message, just inherit from class io.github.rhwayfun.springboot.rocketmq.starter.common.AbstractRocketMqConsumer

Example:

@Component
    public class DemoMqConsumer extends AbstractRocketMqConsumer<DemoMqTopic, DemoMqContent> {


        @Override
        public boolean consumeMsg(RocketMqContent content, MessageExt msg) {
            System.out.println(new Date() + ", " + content);
            return true;
        }

        @Override
        public Map<String, Set<String>> subscribeTopicTags() {
            Map<String, Set<String>> map = new HashMap<>();
            Set<String> tags = new HashSet<>();
            tags.add("test-tag");
            map.put("test-topic", tags);
            return map;
        }

        @Override
        public String getConsumerGroup() {
            return "test-consumer-group";
        }
    }

    public class DemoMqTopic implements RocketMqTopic{

        @Override
        public String getTopic() {
            return "test-topic";
        }
    }

    public class DemoMqContent extends RocketMqContent {
        private int id;
        private String desc;

        public int getId() {
            return id;
        }

        public void setId(int id) {
            this.id = id;
        }

        public String getDesc() {
            return desc;
        }

        public void setDesc(String desc) {
            this.desc = desc;
        }
    }

Send message

We encapsulate the part of the message sent for common use. The default implementation is DefaultRocketMqProducer.

if you need send message with RocketMQ, autowire this bean in your application.

example:

@Component
public class DemoRocketMqProducerExample {

    @Resource
    private DefaultRocketMqProducer producer; //this bean is provided by default.

    @PostConstruct
    public void execute() {
        new Timer().schedule(new TimerTask() {
            @Override
            public void run() {
                DemoRocketMqContent content = new DemoRocketMqContent();
                content.setCityId(1);
                content.setDesc("城市");
                Message msg = new Message("TopicA", "TagA", content.toString().getBytes());
                boolean sendResult = producer.sendMsg(msg);
                System.out.println("发送结果:" + sendResult);
            }
        }, 0, 10000);
    }

}

More configurations

num config description default
1 spring.rocketmq.nameServer name server
2 spring.rocketmq.producerGroupName name of producer
3 spring.rocketmq.producerSendMsgTimeout millis of send message timeout 3000
4 spring.rocketmq.producerCompressMsgBodyOverHowMuch Compress message body threshold 4000
5 spring.rocketmq.producerRetryTimesWhenSendFailed Maximum number of retry to perform internally before claiming sending failure in synchronous mode 2
6 spring.rocketmq.producerRetryTimesWhenSendAsyncFailed Maximum number of retry to perform internally before claiming sending failure in asynchronous mode 2
7 spring.rocketmq.producerRetryAnotherBrokerWhenNotStoreOk Indicate whether to retry another broker on sending failure internally false
8 spring.rocketmq.producerMaxMessageSize Maximum allowed message size in bytes 1024 * 4

License

Adopting the Apache License 2.0 protocol for licensing