本文分享自华为云社区《- : 实战与源码解析一网打尽-云社区-华为云》,作者:勇哥java实战分享。

是大家耳熟能详的消息队列,开源项目 – 可以帮助开发者在 Boot 项目中快速整合 。

这篇文章会介绍 Boot 项目使用 – SDK 实现消息收发的操作流程,同时笔者会从开发者的角度解读 SDK 的设计逻辑。

免费java源码网,0,43,-1,免费网站java源码大全-项目实战大全 提升经验的最好...,https://www.xnbaoku.com/37921/.html_源码库官网_源码大全下载

1 SDK 简介

项目地址:

– 的本质是一个 Boot 。

Boot 基于“约定大于配置”( over )这一理念来快速地开发、测试、运行和部署 应用,并能通过简单地与各种启动器(如 -boot-web-)结合,让应用直接以命令行的方式运行免费java源码网,0,43,-1,免费网站java源码大全-项目实战大全 提升经验的最好…,https://www.xnbaoku.com/37921/.html,不需再部署到独立容器中。

Boot 构造的启动器使用起来非常方便,开发者只需要在 pom.xml 引入 的依赖定义,在配置文件中编写约定的配置即可。

下面我们看下 –boot- 的配置:

1、引入依赖


  org.apache.rocketmq
  rocketmq-spring-boot-starter
  2.2.3

2、约定配置

源码大全下载_免费java源码网,0,43,-1,免费网站java源码大全-项目实战大全 提升经验的最好...,https://www.xnbaoku.com/37921/.html_源码库官网

接下来,我们分别按照生产者和消费者的顺序,详细的讲解消息收发的操作过程。

2 生产者

首先我们添加依赖后,进行如下三个步骤:

1、配置文件中配置如下

rocketmq:
  name-server: 127.0.0.1:9876
  producer:
      group: platform-sms-server-group
    # access-key: myaccesskey
    # secret-key: mysecretkey
  topic: sms-common-topic

生产者配置非常简单,主要配置名字服务地址和生产者组。

2、需要发送消息的类中注入

@Autowired
private RocketMQTemplate rocketMQTemplate;
@Value("${rocketmq.topic}")
private String smsTopic;

3、发送消息,消息体可以是自定义对象,也可以是 对象

类包含多钟发送消息的方法:

同步发送 异步发送 顺序发送 y发送

下面的代码展示如何同步发送消息。

String destination = StringUtils.isBlank(tags) ? topic : topic + ":" + tags;
SendResult sendResult =
         rocketMQTemplate.syncSend(
            destination, 
            MessageBuilder.withPayload(messageContent).
            setHeader(MessageConst.PROPERTY_KEYS, uniqueId).
            build()
          );
if (sendResult != null) {
    if (sendResult.getSendStatus() == SendStatus.SEND_OK) {
       // send message success ,do something 
    }
}

方法的第一个参数是发送的目标,格式是:topic + “:” + tags ,

第二个参数是:- 规范的 对象 ,而 是一个工具类,方法链式调用创建消息对象。

3 消费者

1、配置文件中配置如下

rocketmq:
  name-server: 127.0.0.1:9876
  consumer1:
    group: platform-sms-worker-common-group
    topic: sms-common-topic

2、实现消息监听器

@Component
@RocketMQMessageListener(
    consumerGroup = "${rocketmq.consumer1.group}",  //消费组
    topic = "${rocketmq.consumer1.topic}"           //主题
)
public class SmsMessageCommonConsumer implements RocketMQListener {
    public void onMessage(String message) {
       System.out.println("普通短信:" + message);
    }
}

消费者实现类也可以实现 , 在 方法里通过 原生消息对象 获取更详细的消息数据 。

public void onMessage(MessageExt message) {
    try {
        String body = new String(message.getBody(), "UTF-8");
        logger.info("普通短信:" + message);
    } catch (Exception e) {
        logger.error("common onMessage error:", e);
    }
}

4 源码概览

源码大全下载_免费java源码网,0,43,-1,免费网站java源码大全-项目实战大全 提升经验的最好...,https://www.xnbaoku.com/37921/.html_源码库官网

最新源码中,我们可以看到源码中包含四个模块:

1、–boot-

该模块是父模块,定义项目所有依赖的 jar 包。

2、–boot

核心模块,实现了 的核心逻辑。

3、–boot-

SDK 模块,简单封装,外部项目引用。

4、–boot-

示例代码模块。这个模块非常重要,当用户使用 SDK 时,可以参考示例快速开发。

5 实现

我们重点分析下 –boot 模块的核心源码:

源码库官网_源码大全下载_免费java源码网,0,43,-1,免费网站java源码大全-项目实战大全 提升经验的最好...,https://www.xnbaoku.com/37921/.html

-boot- 实现需要包含如下三个部分:

1、定义 自身的依赖包和 的依赖包 ;

2、定义. 文件

在 包下创建 META-INF 目录后,新建 . 文件,并在文件中定义自动加载类,文件内容是:

org.springframework.boot.autoconfigure.EnableAutoConfiguration=
org.apache.rocketmq.spring.autoconfigure.RocketMQAutoConfiguration

boot 会根据文件中配置的自动化配置类来自动初始化相关的 Bean、 或 。

3、实现自动加载类

在 ation 类的具体实现中,我们重点分析下生产者和消费者是如何分别启动的。

▍生产者发送模板类:

ation 类定义了两个默认的 Bean :

免费java源码网,0,43,-1,免费网站java源码大全-项目实战大全 提升经验的最好...,https://www.xnbaoku.com/37921/.html_源码库官网_源码大全下载

首先项目中配置文件中的配置值会根据属性条件绑定到 对象 中,然后使用 的原生 API 分别创建生产者 Bean 和拉取消费者 Bean , 分别将两个 bean 设置到 对象中。

两个重点需要强调:

类封装了拉取消费者的方法,以方便开发者使用。

源码库官网_源码大全下载_免费java源码网,0,43,-1,免费网站java源码大全-项目实战大全 提升经验的最好...,https://www.xnbaoku.com/37921/.html

▍自定义消费者类

下图是并发消费者的例子:

免费java源码网,0,43,-1,免费网站java源码大全-项目实战大全 提升经验的最好...,https://www.xnbaoku.com/37921/.html_源码大全下载_源码库官网

那么 – 是如何自动启动消费者呢 ?

源码大全下载_免费java源码网,0,43,-1,免费网站java源码大全-项目实战大全 提升经验的最好...,https://www.xnbaoku.com/37921/.html_源码库官网

容器首先注册了消息监听器后置处理器,然后调用 类的 方法 。

对比并发消费者的例子,我们可以看到: 是对 r 消费逻辑的封装。

封装消费消息的逻辑,同时满足 泛化接口支持不同参数,比如 、 、自定义对象 。

首先初始化之后, 获取 方法的参数类型 。

免费java源码网,0,43,-1,免费网站java源码大全-项目实战大全 提升经验的最好...,https://www.xnbaoku.com/37921/.html_源码大全下载_源码库官网

然后消费者调用 处理消息时,封装了一个 方法 ,将原生 消息对象 转换成 方法定义的参数对象,然后调用 的 方法。

上图右侧标红的代码也就是该方法的精髓:

rocketMQListener.onMessage(doConvertMessage(messageExt));

6 写到最后

开源项目 – 有很多值得学习的地方 ,我们可以从如下四个层面逐层进阶:

1、学会如何使用 :参考 –boot- 模块的示例代码,学会如何发送和接收消息,快速编码;


娜娜项目网每日更新创业和副业项目

网址:nanaxm.cn 点击前往娜娜项目网

站 长 微 信: nanadh666


2、模块设计:学习项目的模块分层 (父模块、SDK 模块、核心实现模块、示例代码模块);

3、 设计思路 :定义自动配置文件 . 、设计配置属性类 、在 的基础上实现优雅的封装、深入理解 源码等;

4、举一反三:当我们理解了 – 的源码,我们可以尝试模仿该项目写一个简单的 boot 。

关注#华为云开发者联盟# 点击下方免费java源码网,0,43,-1,免费网站java源码大全-项目实战大全 提升经验的最好…,https://www.xnbaoku.com/37921/.html,第一时间了解华为云新鲜技术~

华为云博客_大数据博客_AI博客_云计算博客_开发者中心-华为云


娜娜项目网每日更新创业和副业项目

网址:nanaxm.cn 点击前往娜娜项目网

站 长 微 信: nanadh666

声明: 本站内容转载于网络,版权归原作者所有,仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任,若侵犯到你的版权利益,请联系我们,会尽快删除处理!