Rabbit 安装踩坑及 Springboot 和 RabbitMQ 整合(Direct 模式、Topic 模式、Fanout 模式)

本贴最后更新于 2311 天前,其中的信息可能已经事过境迁

一: RabbitMQ
1.由于 RabbitMQ 是由 Elang 语言开发的,所以安装 RabbitMQ 需要首先安装 Elang 环境(需要添加入环境变量才可以正常启动 RabbitMQ)。
2.在安装过程中需要注意 ERlang 和 RabbitMQ 的版本对应,如果版本不正确的话也会导致 RabbitMQ 安装失败。
3.当使用 springboot 去远程连接 rabbitMQ 时,不能使用默认的 guest 用户,官方文档也写到,该用户引用于本地连接使用。
4.RabbitMQ 有 web 的 UI 界面,不过需要启动(rabbitmq-plugins.bat enable rabbitmq_management 命令),windows\linux 下如果启动不成功,可能是没有在管理员的权限下进行运行。开启和关闭 RabbitMQ 的命令分别为 net start\stop RabbitMQ。

二:Springboot 和 RabbitMQ 整合
创建 maven 项目并导入需要的 jar 包

<dependencies> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-amqp</artifactId> </dependency> <dependency> <groupId>com.rabbitmq</groupId> <artifactId>amqp-client</artifactId> <version>3.6.5</version> </dependency> <dependency> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-test</artifactId> </dependency> </dependencies>

并配置好 application.properties:

spring.application.name=Spring-boot-rabbitmq spring.rabbitmq.host=localhost spring.rabbitmq.port=5672 spring.rabbitmq.username=#username spring.rabbitmq.password=#password

1.Direct 模式:最简单的消息队列模式

RabbitConfig.java:RabbitMQ 的配置类,在这里可以定义一个消息队列。

@Configuration public class RabbitConfig { @Bean public Queue Queue(){ // ("hello") 值得是创建这个队列的名字 return new Queue("hello"); } }

HelloSender.java: 发送端的编写

@Service public class HelloSender { @Autowired private AmqpTemplate rabbitTemplate; public void send(int i ){ String context = "hello" + new Date(); System.out.println("Sender:" + context + "******" + i); // 这里需要指定发送的消息队列 this.rabbitTemplate.convertAndSend("hello",context); } }

HelloReceiver.java: 接收端的编写

@Component @RabbitListener(queues = "hello") public class HelloReceiver { @RabbitHandler public void process1(String hello){ System.out.println("Receiver1:" + hello); } }

TestRabbitMQ:对于队列的发送测试

@SpringBootTest @RunWith(SpringJUnit4ClassRunner.class) public class TestRabbitMQ { @Autowired private HelloSender helloSender; @Test public void testRabbit(){ helloSender.send(1); } }

最后编写 springboot 的项目启动类后启动,会看到发送端和接收端的数据。


2.Topic 模式:可以自定义接收队列的模式,是最灵活的一种。

RabbitConfig 中创建两个消息队列,把其都绑定在同一个交换机中,通过 with 来限定满足什么条件的时候接收器触发。

@Configuration public class RabbitConfig { // 创建 queue @Bean(name = "message") public Queue Queue(){ return new Queue("topic.message"); // topic.message ,是 rounting-key 匹配规则 } @Bean(name = "messages") public Queue queueMessages(){ return new Queue("topic.messages"); } /** * 创建交换机 * @return */ @Bean public TopicExchange exchange(){ return new TopicExchange("exchange"); } // 根据绑定规则将队列绑定到相应的交换机上 @Bean public Binding bindingExchangeMessage(@Qualifier("message") Queue queueMessage, TopicExchange exchange){ return BindingBuilder.bind(queueMessage).to(exchange).with("topic.message"); } @Bean public Binding bindingExchangeMessages(@Qualifier("messages") Queue queueMessages, TopicExchange exchange){ // * 表示一个词, # 表示零个或多个词 return BindingBuilder.bind(queueMessages).to(exchange).with("topic.#"); } }

当发送的消息是 queueMessage 的时候两个接收器都会接受,而当发送的消息是 queueMessages 的时候只有第二个接收器会接受。


3.Fanout 模式:意为广播模式,可以同时分发到绑定交换机的所有接收器。

RabbitMQ 中编写了 3 个消息队列,把其都绑定在交换机上。

@Configuration /** * 广播模式 Fanout */ public class FanoutRabbitConfig { @Bean public Queue AMessage(){ return new Queue("fanout.A"); } @Bean public Queue BMessage(){ return new Queue("fanout.B"); } @Bean public Queue CMessage(){ return new Queue("fanout.C"); } // 构建交换器 @Bean FanoutExchange fanoutExchange(){ return new FanoutExchange("fanoutExchange"); } // 把 A,B,C都绑到 fanoutExchange 上 @Bean Binding bindingExchangeA(Queue AMessage , FanoutExchange fanoutExchange){ return BindingBuilder.bind(AMessage).to(fanoutExchange); } @Bean Binding bindingExchangeB(Queue BMessage , FanoutExchange fanoutExchange){ return BindingBuilder.bind(BMessage).to(fanoutExchange); } @Bean Binding bindingExchangeC(Queue CMessage , FanoutExchange fanoutExchange){ return BindingBuilder.bind(CMessage).to(fanoutExchange); } }

运行的结果是当发送消息的时候交换器会将其分发到 3 个接收器上

  • Spring

    Spring 是一个开源框架,是于 2003 年兴起的一个轻量级的 Java 开发框架,由 Rod Johnson 在其著作《Expert One-On-One J2EE Development and Design》中阐述的部分理念和原型衍生而来。它是为了解决企业应用开发的复杂性而创建的。框架的主要优势之一就是其分层架构,分层架构允许使用者选择使用哪一个组件,同时为 JavaEE 应用程序开发提供集成的框架。

    946 引用 • 1460 回帖 • 1 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • 小薇

    小薇是一个用 Java 写的 QQ 聊天机器人 Web 服务,可以用于社群互动。

    由于 Smart QQ 从 2019 年 1 月 1 日起停止服务,所以该项目也已经停止维护了!

    34 引用 • 467 回帖 • 759 关注
  • 生活

    生活是指人类生存过程中的各项活动的总和,范畴较广,一般指为幸福的意义而存在。生活实际上是对人生的一种诠释。生活包括人类在社会中与自己息息相关的日常活动和心理影射。

    230 引用 • 1454 回帖 • 2 关注
  • SendCloud

    SendCloud 由搜狐武汉研发中心孵化的项目,是致力于为开发者提供高质量的触发邮件服务的云端邮件发送平台,为开发者提供便利的 API 接口来调用服务,让邮件准确迅速到达用户收件箱并获得强大的追踪数据。

    2 引用 • 8 回帖 • 485 关注
  • 旅游

    希望你我能在旅途中找到人生的下一站。

    93 引用 • 901 回帖
  • WiFiDog

    WiFiDog 是一套开源的无线热点认证管理工具,主要功能包括:位置相关的内容递送;用户认证和授权;集中式网络监控。

    1 引用 • 7 回帖 • 609 关注
  • Ngui

    Ngui 是一个 GUI 的排版显示引擎和跨平台的 GUI 应用程序开发框架,基于
    Node.js / OpenGL。目标是在此基础上开发 GUI 应用程序可拥有开发 WEB 应用般简单与速度同时兼顾 Native 应用程序的性能与体验。

    7 引用 • 9 回帖 • 399 关注
  • 友情链接

    确认过眼神后的灵魂连接,站在链在!

    24 引用 • 373 回帖
  • 职场

    找到自己的位置,萌新烦恼少。

    127 引用 • 1708 回帖
  • ngrok

    ngrok 是一个反向代理,通过在公共的端点和本地运行的 Web 服务器之间建立一个安全的通道。

    7 引用 • 63 回帖 • 648 关注
  • RIP

    愿逝者安息!

    8 引用 • 92 回帖 • 393 关注
  • Bootstrap

    Bootstrap 是 Twitter 推出的一个用于前端开发的开源工具包。它由 Twitter 的设计师 Mark Otto 和 Jacob Thornton 合作开发,是一个 CSS / HTML 框架。

    18 引用 • 33 回帖 • 655 关注
  • 锤子科技

    锤子科技(Smartisan)成立于 2012 年 5 月,是一家制造移动互联网终端设备的公司,公司的使命是用完美主义的工匠精神,打造用户体验一流的数码消费类产品(智能手机为主),改善人们的生活质量。

    4 引用 • 31 回帖 • 5 关注
  • FFmpeg

    FFmpeg 是一套可以用来记录、转换数字音频、视频,并能将其转化为流的开源计算机程序。

    23 引用 • 32 回帖 • 2 关注
  • IDEA

    IDEA 全称 IntelliJ IDEA,是一款 Java 语言开发的集成环境,在业界被公认为最好的 Java 开发工具之一。IDEA 是 JetBrains 公司的产品,这家公司总部位于捷克共和国的首都布拉格,开发人员以严谨著称的东欧程序员为主。

    181 引用 • 400 回帖
  • Sym

    Sym 是一款用 Java 实现的现代化社区(论坛/BBS/社交网络/博客)系统平台。

    下一代的社区系统,为未来而构建

    524 引用 • 4601 回帖 • 702 关注
  • 互联网

    互联网(Internet),又称网际网络,或音译因特网、英特网。互联网始于 1969 年美国的阿帕网,是网络与网络之间所串连成的庞大网络,这些网络以一组通用的协议相连,形成逻辑上的单一巨大国际网络。

    99 引用 • 367 回帖
  • Vditor

    Vditor 是一款浏览器端的 Markdown 编辑器,支持所见即所得、即时渲染(类似 Typora)和分屏预览模式。它使用 TypeScript 实现,支持原生 JavaScript、Vue、React 和 Angular。

    366 引用 • 1842 回帖 • 1 关注
  • V2Ray
    1 引用 • 15 回帖 • 1 关注
  • 书籍

    宋真宗赵恒曾经说过:“书中自有黄金屋,书中自有颜如玉。”

    77 引用 • 389 回帖
  • PHP

    PHP(Hypertext Preprocessor)是一种开源脚本语言。语法吸收了 C 语言、 Java 和 Perl 的特点,主要适用于 Web 开发领域,据说是世界上最好的编程语言。

    179 引用 • 408 回帖 • 484 关注
  • Notion

    Notion - The all-in-one workspace for your notes, tasks, wikis, and databases.

    10 引用 • 76 回帖
  • WebComponents

    Web Components 是 W3C 定义的标准,它给了前端开发者扩展浏览器标签的能力,可以方便地定制可复用组件,更好的进行模块化开发,解放了前端开发者的生产力。

    1 引用 • 8 关注
  • uTools

    uTools 是一个极简、插件化、跨平台的现代桌面软件。通过自由选配丰富的插件,打造你得心应手的工具集合。

    7 引用 • 27 回帖
  • Log4j

    Log4j 是 Apache 开源的一款使用广泛的 Java 日志组件。

    20 引用 • 18 回帖 • 31 关注
  • danl
    164 关注
  • Webswing

    Webswing 是一个能将任何 Swing 应用通过纯 HTML5 运行在浏览器中的 Web 服务器,详细介绍请看 将 Java Swing 应用变成 Web 应用

    1 引用 • 15 回帖 • 638 关注
  • JetBrains

    JetBrains 是一家捷克的软件开发公司,该公司位于捷克的布拉格,并在俄国的圣彼得堡及美国麻州波士顿都设有办公室,该公司最为人所熟知的产品是 Java 编程语言开发撰写时所用的集成开发环境:IntelliJ IDEA

    18 引用 • 54 回帖