Java 实现消息消费|学习笔记

简介: 快速学习 Java 实现消息消费

开发者学堂课程【全面讲解 Spring Cloud Alibaba 技术栈(知识精讲+项目实战)第四阶段Java 实现消息消费】学习笔记,与课程紧密联系,让用户快速学习知识。

课程地址https://developer.aliyun.com/learning/course/686/detail/11907


Java 实现消息消费


内容介绍:

一、Java 实现消息消费

二、案例


一、Java 实现消息消费

 Java 代码进行消费,给予的是订阅机制也可以认为是接听机制。

1、消息接收步骤:

1创建消息消费者,指定消费者所属的组名

2指定 Nameserver 地址

3指定消费者订阅的主题和标签

4设置回调函数,编写处理消息的方法(消费者会一直监听 MQ,一旦发现消息用回调方式进行处理)

5启动消息消费者

//接收消息

public class RocketMQReceiveTest {

public static void main(string[] args) throws

mqclientException {

//1.创建消息消费者,指定消费者所属的组名

DefaultMQPushConsumer consumer

=newDefau1tMQPushCon sumer("myconsumer-group")

//2.指定 Nameserver地址

consumer.setNamesrvAddr("192.168.109.131:9876)

//3.指定消费者订阅的主题和标签

consumer.subscribe("myTopic",""");

//4.设置回调函数,编写处理消息的方法

consumer.registerMessageListener(new

MessageListenerConc urrently{

@Override

public ConsumeConcurrentlystatus

consumeMessaqe(List<Me ssaqeExt> msqs,

ConsumeConcurrentlyContextcontext){

System.out.print1n("Receive New Messages:"+ msgs);

//返回消费状态

return ConsumeConcurrentlyStatusCONSUMESUCCESS;

}

});

//5.启动消息消费者 consumer.start();

system.out.print1n("Consumer Started.");

}

}

2、处理

打开工程新加一个类 New-Java Class

接收消息的测试

package com.itheima.test;

public class RocketMQReceiveMessageTest{

//接收消息

public static void main(string[] args){

//1创建消费者,并且为其指定消费者组名

new DefaultMQPushConsumer consumer = new DefaultMQ

PushConsumer(consumerGroup:“myconsumer-group“);

//2为消费者设置 NameServer 的地址

consumer.setNamesrvAddr("192.168.109.131:9876");

//3指定消费者订阅的主题和标签

consumer.subscribe(topic:"myTopic",subExpression:"*");

//4设置一个回调函数,并在函数中编写接收到消息之后的处理方法

consumer.registerMessageListener(new

MessageListenerConc urrently() {

//处理获取到的消息

@Override

public ConsumeConcurrentlystatus consumeMessage(List<Me ssaqeext>

list,Consumeconcurrentlycontext consumeconcurrentlyContext){

//消费逻辑

system.out.println("Message--->" + list);

//返回消费成功状态

return ConsumeConcurrentlyStatus.CONSUME SUCCESS

});

//5 启动消费者

consumer.start);

system.out.println("启动消费者成功了");

}

}

启动消费者运行:

C:\Java\jdk1.8.0\bin\java.exe ...

启动消费者成功了

Messaqe===>[MessaqeExt [queueId=1,storeSize=182,

queue Offset=0,sysFlaq=0,

bornTimestamp=1577690976503,bornHo st=/

192.168.109.1:65029,storeTimestamp=1577690975351,

storeHost=/192.168.109.131:10911,msgId=C

消费者启动成功消息已经被消费,进程不会退出去一直等待,因为是基于监督机制。

还可以再发送一个消息,消费者现在只消费了一条,再来到发送启动:

c:\Java\jdk1.8.0\bin\java.exe ...

Sendresult [sendstatus=SEND OK,msgId=C0A82B9058E658

644D4698B7F5270000,

offsetMsId=C0A86D8300002A9F00000 00000AFA1A,

message

15:43:12.715 [Nettyclientselector1] INFO

RocketmqRemotin g-closechannel: close the connection to remote address[192.168.10915:43:12.724 [NettyclientSelector 1] INFO

RocketmgRemoting- closechannel: close the connection to remote address[192.168.109

15:43:12.724 [NettyclientSelector 11 INFO

RocketmgRemoting - closeChannel; close the connection to remote address[192.168.109

Process finished with exit code 0

消费者结果:

c:\Java\jdk1.8.0\bin\java.exe..启动消费者成功了

Message===>[MessageExt[queueId=1,storesize=182,

queue Offset=0,

sysFlag=0,bornTimestamp=1577690976503, born Host=/

192.168.109.1:65029,storeTimestamp=1577690975351,

storeHost=/192.168.109.131:10911,msgId=C

Message===> [MessageExt[queueId=3, storesize=182,

queue offset=0, sysflag=0,

bornTimestamp=1577691792680, bornH ost=/

192.168.109.1:49417,storeTimestamp=1577691791527,

storeHost=/192.168.109.131:10911,msqId=C

自动消费掉,关键是了解代码的大体逻辑以及内部的定额,内部的订阅机制是利用的监听,当一旦发现有消息过来,自动内部进行消费。


二、案例

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

image.png

把代码应用到案例中去,下单成功以后会发送一个消息放到 MQ 中,通过另一个微服 MQ 中取消息

相关实践学习
快速体验阿里云云消息队列RocketMQ版
本实验将带您快速体验使用云消息队列RocketMQ版Serverless系列实例进行获取接入点、创建Topic、创建订阅组、收发消息、查看消息轨迹和仪表盘。
消息队列 MNS 入门课程
1、消息队列MNS简介 本节课介绍消息队列的MNS的基础概念 2、消息队列MNS特性 本节课介绍消息队列的MNS的主要特性 3、MNS的最佳实践及场景应用 本节课介绍消息队列的MNS的最佳实践及场景应用案例 4、手把手系列:消息队列MNS实操讲 本节课介绍消息队列的MNS的实际操作演示 5、动手实验:基于MNS,0基础轻松构建 Web Client 本节课带您一起基于MNS,0基础轻松构建 Web Client
相关文章
|
4月前
|
Java API 微服务
2025 年 Java 从入门到精通学习笔记全新版
《Java学习笔记:从入门到精通(2025更新版)》是一本全面覆盖Java开发核心技能的指南,适合零基础到高级开发者。内容包括Java基础(如开发环境配置、核心语法增强)、面向对象编程(密封类、接口增强)、进阶技术(虚拟线程、结构化并发、向量API)、实用类库与框架(HTTP客户端、Spring Boot)、微服务与云原生(容器化、Kubernetes)、响应式编程(Reactor、WebFlux)、函数式编程(Stream API)、测试技术(JUnit 5、Mockito)、数据持久化(JPA、R2DBC)以及实战项目(Todo应用)。
221 5
|
14天前
|
小程序 Java 知识图谱
Java 学习笔记 —— BMI & BMR 计算器
这是一个使用 Java 编写的 BMI 与 BMR 计算器小程序,可输入年龄、性别、身高和体重,计算身体质量指数(BMI)和基础代谢率(BMR),并输出健康评估结果。通过该项目,掌握了 Java 的输入处理、数据验证、条件判断、数学运算及格式化输出等基础知识,是 Java 初学者的理想练习项目。
|
14天前
|
Java
Java 数组学习笔记
本文整理Java数组常用操作:遍历、求和、查找、最值及二维数组行求和等典型练习,涵盖静态初始化、元素翻倍、去极值求平均等实例,帮助掌握数组基础与应用。
|
7月前
|
存储 Java
# 【Java全栈学习笔记-U1-day02】变量+数据类型+运算符
本篇笔记主要围绕Java全栈学习的第二天内容展开,涵盖了变量、数据类型、运算符以及Scanner类的应用。首先介绍了变量的概念与命名规范,以及如何定义和使用变量;接着详细讲解了Java中的基本数据类型,包括整型、浮点型、字符型、布尔型等,并通过实例演示了数据类型的运用。随后,深入探讨了各类运算符(赋值、算术、关系、逻辑)及其优先级,帮助理解表达式的构成。最后,介绍了如何利用Scanner类实现用户输入功能,并通过多个综合示例(如计算圆面积、购物打折、变量交换及银行利息计算)巩固所学知识。完成相关作业将进一步加深对这些基础概念的理解与实践能力。
100 13
|
存储 Java
Java学习笔记 List集合的定义、集合的遍历、迭代器的使用
Java学习笔记 List集合的定义、集合的遍历、迭代器的使用
285 4
|
7月前
|
开发框架 Java 开发工具
【Java全栈学习笔记-U1-day01】Java介绍
本笔记整理了Java学习的基础内容,涵盖程序理解、Java语言特性、JDK安装与配置、Java程序开发工具及编写步骤。重点介绍了Java程序的基本结构、编译和运行过程,以及输出语句的使用。通过实例演示了IDEA创建Java程序的方法,并强调了编码规范和注意事项。适合初学者复习和交流学习。 主要内容: 1. 理解程序:计算机组成、程序定义。 2. 简介:Java语言特点、技术平台、JDK作用。 3. 编写Java程序:编写、编译、运行步骤,基本结构。 4. 输出语句 5. DEA使用:新建工程、保存位置、文件介绍、新建类。 6. 扩展:注释、代码规范、大小写敏感、缩进等。
|
存储 安全 Java
Java修仙之路,十万字吐血整理全网最完整Java学习笔记(基础篇)
从Java环境的搭建到实际代码的编写,从基本用法的讲解到底层原理的剖析,深度解析Java基础知识。本文是《Java学习路线》专栏的起始文章,旨在提供一套完整的Java学习路线,覆盖Java基础知识、数据库、SSM/SpringBoot等框架、Redis/MQ等中间件、设计模式、架构设计、性能调优、源码解读、核心面试题等全面的知识点,并在未来不断更新和完善,帮助Java从业者在更短的时间内成长为高级开发。
Java修仙之路,十万字吐血整理全网最完整Java学习笔记(基础篇)
|
存储 安全 Java
Java修仙之路,十万字吐血整理全网最完整Java学习笔记(进阶篇)
本文是Java基础的进阶篇,对异常、集合、泛型、Java8新特性、I/O流等知识进行深入浅出的介绍,并附有对应的代码示例,重要的地方带有对性能、底层原理、源码的剖析。适合Java初学者。
Java修仙之路,十万字吐血整理全网最完整Java学习笔记(进阶篇)
|
11月前
|
Java 数据库连接 API
Spring 框架的介绍(Java EE 学习笔记02)
Spring是一个由Rod Johnson开发的轻量级Java SE/EE一站式开源框架,旨在解决Java EE应用中的多种问题。它采用非侵入式设计,通过IoC和AOP技术简化了Java应用的开发流程,降低了组件间的耦合度,支持事务管理和多种框架的无缝集成,极大提升了开发效率和代码质量。Spring 5引入了响应式编程等新特性,进一步增强了框架的功能性和灵活性。
191 0
|
SQL druid Java
Java数据库部分(MySQL+JDBC)(二、JDBC超详细学习笔记)(下)
Java数据库部分(MySQL+JDBC)(二、JDBC超详细学习笔记)
148 3
Java数据库部分(MySQL+JDBC)(二、JDBC超详细学习笔记)(下)