当前位置: 首页 > news >正文

Rocketmq--消息发送和接收演示

使用Java代码来演示消息的发送和接收

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

1 发送消息

        消息发送步骤:

  • 创建消息生产者, 指定生产者所属的组名
  • 指定Nameserver地址
  • 启动生产者
  • 创建消息对象,指定主题、标签和消息体
  • 发送消息
  • 关闭生产者
//发送消息
public class RocketMQSendTest {public static void main(String[] args) throws Exception {//1. 创建消息生产者, 指定生产者所属的组名DefaultMQProducer producer = new DefaultMQProducer("myproducer-group");//2. 指定Nameserver地址producer.setNamesrvAddr("192.168.109.131:9876");//3. 启动生产者producer.start();//4. 创建消息对象,指定主题、标签和消息体Message msg = new Message("myTopic", "myTag",("RocketMQ Message").getBytes());//5. 发送消息SendResult sendResult = producer.send(msg,10000);System.out.println(sendResult);//6. 关闭生产者producer.shutdown();}
}

2 接收消息

        消息接收步骤:

  • 创建消息消费者, 指定消费者所属的组名
  • 指定Nameserver地址
  • 指定消费者订阅的主题和标签
  • 设置回调函数,编写处理消息的方法
  • 启动消息消费者
//接收消息
public class RocketMQReceiveTest {public static void main(String[] args) throws MQClientException {//1. 创建消息消费者, 指定消费者所属的组名DefaultMQPushConsumer consumer = new DefaultMQPushConsumer("myconsumer-
group");//2. 指定Nameserver地址consumer.setNamesrvAddr("192.168.109.131:9876");//3. 指定消费者订阅的主题和标签consumer.subscribe("myTopic", "*");//4. 设置回调函数,编写处理消息的方法consumer.registerMessageListener(new MessageListenerConcurrently() {@Overridepublic ConsumeConcurrentlyStatus consumeMessage(List<MessageExt>
msgs,ConsumeConcurrentlyContext
context) {System.out.println("Receive New Messages: " + msgs);//返回消费状态return ConsumeConcurrentlyStatus.CONSUME_SUCCESS;}});//5. 启动消息消费者consumer.start();System.out.println("Consumer Started.");}
}

3 案例

接下来我们模拟一种场景: 下单成功之后,向下单用户发送短信。设计图如下:

3.1  订单微服务发送消息

1 在 shop-order 中添加rocketmq的依赖

<!--rocketmq-->
<dependency><groupId>org.apache.rocketmq</groupId><artifactId>rocketmq-spring-boot-starter</artifactId><version>2.0.2</version>
</dependency>
<dependency><groupId>org.apache.rocketmq</groupId><artifactId>rocketmq-client</artifactId><version>4.4.0</version>
</dependency>

2 添加配置

rocketmq:
name-server: 192.168.109.131:9876  #rocketMQ服务的地址
producer:group: shop-order # 生产者组

3 编写测试代码

@RestController
@Slf4j
public class OrderController2 {@Autowiredprivate OrderService orderService;@Autowiredprivate ProductService productService;@Autowiredprivate RocketMQTemplate rocketMQTemplate;//准备买1件商品@GetMapping("/order/prod/{pid}")public Order order(@PathVariable("pid") Integer pid) {log.info(">>客户下单,这时候要调用商品微服务查询商品信息");//通过fegin调用商品微服务Product product = productService.findByPid(pid);if (product == null){Order order = new Order();order.setPname("下单失败");return order;}log.info(">>商品信息,查询结果:" + JSON.toJSONString(product));Order order = new Order();order.setUid(1);order.setUsername("测试用户");order.setPid(product.getPid());order.setPname(product.getPname());order.setPprice(product.getPprice());order.setNumber(1);orderService.save(order);//下单成功之后,将消息放到mq中rocketMQTemplate.convertAndSend("order-topic", order);return order;}
}

http://www.lryc.cn/news/169938.html

相关文章:

  • ArcGIS Pro将SHP文件转CAD并保留图层名称
  • GEE:使用for循环合成时间序列影像
  • flink1.13.2版本的对应的hive的Hcatalog的使用记录
  • STM32 ADC介绍和应用
  • vue项目打包_以生产环境prod模式打包_vue-cli-service 不是内部或外部命令,也不是可运行的程序---vue工作笔记0025
  • FreeSWITCH的liberal dtmf
  • 透明度模糊Android实现
  • JavaScript学习笔记04
  • 18 Python的sys模块
  • Spring Boot 各版本的支持时间
  • 华为云云耀云服务器L实例评测|Git 私服搭建指南
  • Linux下的Swap内存
  • Unity中程序集dll
  • 识典百科取代快懂百科,如何在识典百科创建词条?
  • 入门python
  • 基于vue的黑马前端项目小兔鲜
  • 细节决定成败!jdbc的List<?> qryList4Sql(String sql)报错-标志符过长
  • ChatGLM Pytorch从0编写Transformer算法
  • 9.18算法
  • 【Spring Bean的生命周期】
  • 信息化发展49
  • linux常用命令(4):mkdir命令(创建目录)
  • 企业架构LNMP学习笔记58
  • [JAVAee]SpringBoot配置文件
  • 复制远程连接到Linux使用VIM打开的内容到Windows
  • 左神算法之中级提升班(9)
  • SmartNews 基于 Flink 的 Iceberg 实时数据湖实践
  • websocket请求通过IteratorAggregate实现流式输出
  • 《C和指针》笔记28:可变参数和stdarg宏
  • Matlab论文插图绘制模板第114期—带图形标记的图