1、安装 RocketMq
docker search rocketmq
docker pull rocketmqinc/rocketmq:4.4.0  
# 建立 name server
docker run -d -p 9876:9876 -v /data/rocketmq/namesrv/logs:/root/logs -v /data/rocketmq/namesrv/store:/root/store --name rmqnamesrv -e "MAX_POSSIBLE_HEAP=100000000" rocketmqinc/rocketmq:4.4.0 sh mqnamesrv  
# 建立 broker.conf
建立目录和broker配置文件: /data/rocketmq/conf/broker.conf
brokerClusterName = DefaultCluster
brokerName = broker-a
brokerId = 0
deleteWhen = 04
fileReservedTime = 48
brokerRole = ASYNC_MASTER
flushDiskType = ASYNC_FLUSH
brokerIP1 = 210.112.133.103
# 建立 broker
docker run -d -p 10911:10911 -p 10909:10909 -v  /data/rocketmq/broker/logs:/root/logs -v  /data/rocketmq/broker/store:/root/store -v  /data/rocketmq/conf/broker.conf:/opt/rocketmq-4.4.0/conf/broker.conf  --name rmqbroker --link rmqnamesrv:namesrv  -e "NAMESRV_ADDR=namesrv:9876" -e "MAX_POSSIBLE_HEAP=200000000" rocketmqinc/rocketmq:4.4.0 sh mqbroker -c /opt/rocketmq-4.4.0/conf/broker.conf  
# 安装控制台
docker pull styletang/rocketmq-console-ng  
docker run -e "JAVA_OPTS=-Drocketmq.config.namesrvAddr=210.112.133.103:9876 -Drocketmq.config.isVIPChannel=false" -p 8001:8080 -t styletang/rocketmq-console-ng  
2、POM 加入 starter
       <!-- https://mvnrepository.com/artifact/org.apache.rocketmq/rocketmq-spring-boot-starter -->
        <dependency>
            <groupId>org.apache.rocketmq</groupId>
            <artifactId>rocketmq-spring-boot-starter</artifactId>
            <version>2.1.1</version>
        </dependency>
3、配置 rocketmq
# rocketmq configuration
rocketmq.name-server=210.112.133.103:9876
rocketmq.producer.group=rocketmq_producer_group
rocketmq.producer.send-message-timeout=3000
4、测试代码
@ApiModel(description= "订单实体")
@Data
@NoArgsConstructor
@AllArgsConstructor
public class Order implements Serializable {
    @ApiModelProperty(value = "主键")
    private Long id;
    @ApiModelProperty(value = "商品名称")
    private String productName;
    @ApiModelProperty(value = "价格")
    private BigDecimal amount;
    @ApiModelProperty(value = "时间")
    private Date createTime;
}
/**
 * 消息生产者
 */
@Service
public class RocketMqProducer {
    private RocketMQTemplate rocketMQTemplate;
    public RocketMqProducer(RocketMQTemplate rocketMQTemplate) {
        this.rocketMQTemplate = rocketMQTemplate;
    }
    public RocketMQTemplate getRocketMQTemplate() {
        return rocketMQTemplate;
    }
}
@Api(value = "订单管理", tags = "管理订单增删改查")
@Log4j2
@RestController
@RequestMapping("/order")
public class OrderController {
    private RocketMqProducer rocketMqProducer;
    public OrderController(RocketMqProducer rocketMqProducer) {
        this.rocketMqProducer = rocketMqProducer;
    }
    @ApiOperation(value = "保存或更新订单", notes = "id、productName、amount都是必输入项")
    @ApiImplicitParams(value = {
            @ApiImplicitParam(name = "id", value = "", dataTypeClass = Long.class, required = true),
            @ApiImplicitParam(name = "productName", value = "", dataTypeClass = String.class, required = true),
            @ApiImplicitParam(name = "amount", value = "", dataTypeClass = BigDecimal.class, required = true)
    })
    @PostMapping("/saveOrUpdate")
    public ResponseEntity<Result<Order>> saveOrUpdate(
            @RequestParam Long id,
            @RequestParam String productName,
            @RequestParam BigDecimal amount
    ) {
        Order order = new Order(id, productName, amount, new Date());
        rocketMqProducer.getRocketMQTemplate().getProducer().setSendMsgTimeout(10000);
        rocketMqProducer.getRocketMQTemplate().convertAndSend(Constants.ROCKET_MQ_ORDER, order);
        return ResultUtils.ok(order);
    }
}
@Log4j2
@Service
@RocketMQMessageListener(topic = Constants.ROCKET_MQ_ORDER, selectorExpression = "*", consumerGroup = Constants.ROCKET_MQ_CONSUMER_GROUP_ORDER)
public class RocketMqOrderConsumerListener implements RocketMQListener<Order> {
    @Override
    public void onMessage(Order order) {
        log.error("【onMessage start】");
        log.error(order.getId());
        log.error(order.getProductName());
        log.error(order.getAmount());
        log.error(order.getCreateTime());
        log.error("【onMessage end】");
    }
}
5、控制台

 
  
  
  
 
 
  
 
 
 