RocketMQ简介

RocketMQ是阿里巴巴开源的消息中间件。目前已经贡献给Apache软件基金会,成为Apache的顶级项目。

rocketMQ基本概念

1. Producer Group

生产者组:是一类生产者的集合,通常发送同一类消息并且发送逻辑一致。

2. Producer

生产者:负责发送消息,有三种消息发送模式。

  • 同步发送:收到确认后再发送下一条消息
  • 异步发送:发送后,不等待确认继续发送下一条
  • 单向发送:只负责发送消息,无法确认并且没有回调,适合收集日志

3. Consumer Group

消费者组:是一类消费者的集合,通常消费同一类消息并且消费逻辑一致。

4. Consumer

消息者:负责消费消息,有两种消费模式

  • 拉取型消费:主动从消息服务器拉取信息,只要批量拉取到消息,用户应用就会启动消费过程
  • 推送型消费:实际上也是拉取消息,只不过是将拉取逻辑进行了封装,将消息到达时执行的回调接口留给用户来实现

5. Broker

消息服务器:存储消息

6. NameServer

作用和zookeeper类似,用来保存broker相关元素,并给producer和consumer查找broker消息,Producer 在发送消息前会根据 Topic 到 NameServer 获取到 Broker 的路由信息,Consumer 也会定时获取 Topic 的路由信息。

7. Topic

消息主题

8. Tag

标签,Topic的二级分类,也可以理解为消息队列,主题被划分为一个或多个子主题,即消息队列。一个 Topic 下可以设置多个消息队列,发送消息时执行该消息的 Topic ,RocketMQ 会轮询该 Topic 下的所有队列将消息发出去。

Spring Boot整合Rocketmq

1. 引入依赖

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

2. 配置rocketmq信息

rocketmq:
name-server: 127.0.0.1:9876
producer:
group: my-producer-group

3. 构建生产者

@RestController
public class Producer { @Autowired
private RocketMQTemplate rocketMQTemplate; @GetMapping("send")
public void send(){ rocketMQTemplate.convertAndSend("first-topic","你好,Java旅途");
}
}

4. 构建消费者

@Component
@RocketMQMessageListener(topic = "first-topic",consumerGroup = "my-consumer-group")
@Slf4j
public class Consumer implements RocketMQListener<String> { @Override
public void onMessage(String message) {
log.info("我收到消息了!消息内容为:"+message);
}
}

emmm,消息队列的内容就暂时告一段落了,文章中只是演示了最简单的收发消息,在实际应用中需要考虑的问题远比这要多。

此是spring-boot-route系列的第十五篇文章,这个系列的文章都比较简单,主要目的就是为了帮助初次接触Spring Boot 的同学有一个系统的认识。本文已收录至我的github,欢迎各位小伙伴star

githubhttps://github.com/binzh303/spring-boot-route

点关注、不迷路

如果觉得文章不错,欢迎关注点赞收藏,你们的支持是我创作的动力,感谢大家。

如果文章写的有问题,请不要吝啬,欢迎留言指出,我会及时核查修改。

如果你还想更加深入的了解我,可以微信搜索「Java旅途」进行关注。回复「1024」即可获得学习视频及精美电子书。每天7:30准时推送技术文章,让你的上班路不在孤独,而且每月还有送书活动,助你提升硬实力!

最新文章

  1. [WCF编程]12.事务:事务传播
  2. 关于Promise模式 整理中。。。
  3. bzoj 3196: Tyvj 1730 二逼平衡树
  4. 什么是FOUC?如何避免FOUC?
  5. 9.链式A+B
  6. Java NIO 与 基于reactor设计模式的事件处理模型
  7. 【VMware虚拟化解决方案】 基于VMware虚拟化平台VDI整体性能分析与优化
  8. Linux用户相关的操作命令
  9. win10 uwp 兴趣线
  10. 求复变函数的 Taylor 展式与 Laurent 展式[华中师范大学2010年复变函数复试试题]
  11. UOJ#55. 【WC2014】紫荆花之恋 点分树 替罪羊树 平衡树 splay Treap
  12. XML外部实体注入漏洞(XXE)
  13. php 实现简拼
  14. 《FPGA全程进阶---实战演练》第三章之接地设计
  15. 170607、SQL Select语句完整的执行顺序
  16. python中os.system()的返回值
  17. GO语言使用gopsutil包进行机器信息采集
  18. idea里绝对不要直接复制文件到项目中的另一处
  19. SSH新学,关于面向对象的看法
  20. IIS反向代理/Rewrite/https卸载配置

热门文章

  1. Nginx升级加固SSL/TLS协议信息泄露漏洞(CVE-2016-2183)
  2. 零基础一分钟入门Python
  3. 微信小程序-组件-基础内容
  4. flutter driver 集成测试
  5. 吴恩达《深度学习》-课后测验-第一门课 (Neural Networks and Deep Learning)-Week 4 - Key concepts on Deep Neural Networks(第四周 测验 – 深层神经网络)
  6. 论如何学习Extjs
  7. java Spring系列之 配置文件的操作 +Bean的生命周期+不同数据类型的注入简析+注入的原理详解+配置文件中不同标签体的使用方式
  8. Linux自动同步时间的方法
  9. (专题四)06 matlab绘图选项卡
  10. mysql 事务、隔离级别