SpringBoot 第二十二篇 之 使用RabbitMQ

1. 简介:

    RabbitMQ是一个在AMQP基础上可复用的企业消息系统。

    AMQP(Advanced(预先) Message Queuing Protocol(协议)) 是一个提供统一消息服务的应用层标准协议,基于此协议的        客户端与消息中间件可传递消息,

     并不受客户端中间件不同产品,不同开发语言的限制。

    RabbitMQ 遵循AMQP协议,用erlang语言开发,用来通过协议在完全不同应用之间共享数据,

    或者将作业排队以便让分布式服务器进行处理。

2. 组件说明

1. Broker: 消息队列服务器实体

2. Exchange:消息交换机,它指定消息按什么规则,路由到哪个队列。

3. Queue:  消息队列的载体,每个消息都会被投入到一个,或多个队列。

4. Binding: 绑定,它的作用就是把exchange和队列按照一定的规则绑定起来。

5. Routing Key : 路由关键字,exchange 根据这个关键字进行消息投递,

6. channel: 消息通道,在客户端的每个链接里,可建立多个channel,每个channel

     代表一个绘画任务。

7. vhost: 虚拟主机,一个broker中可开设多个vhost,用作不同用户的权限分离。

8. producer: 消息生产者。

9. consumer: 消息消费者。

 

10. 消息队列的使用过程:

    (1)生产者链接到服务器,声明一个exchange,并设置交换机类型等属性。

    (2)消费者 连接到消息队列服务器,打开一个channel

    (3)消费者 声明一个queue,并设置相关属性。

    (4)消费者 使用routing key, 绑定 exchange 和 queue。

    (5)生产者 投递消息到exchange

    (6)exchange 接收到消息后,根据消息的key和已经设置的binding,进行消息路由,将消息

             投递到一个或多个队列。

总结:

   使用rabbitmq 可以解耦应用程序,使用消息在应用程序中进行传递,

   将一些无需及时返回且耗时的操作提取出来,进行异步处理,可节省服务器相应时间,

    提高系统吞吐量。

2. 安装

    安装rabbitmq前,先要安装erlang 并配置好环境变量(erlang_home, path 都要设)。

    2.1.  监测erlang 是否安装好的方法是:

     cmd到erlang安装目录的bin文件夹下:

       erl -version

    2.2  监测rabbitmq是否安装好的方法是:

        cmd到安装目录的sbin目录下,运行

        rabbitmqctl status

 

3. springboot 使用 rabbitmq 示例:

     Rabbit MQ 服务器 会根据路由键将消息从交换路由到消息队列中,如何处理投递多个队列的情况?

   这里不同类型的交换机起到了重要作用。分别是 fanout,direct,topic, 每种类型实现了不同的路由算法。

 

     3.1 使用 Fanout  Exchange 交换机

         当使用Fanout Exchange 时,无需处理路由键,很像子广播,

          每一台与该交换机绑定的队列都会获得一份消息。

          Fanout 交换机处理消息是最快的。

       示例:

          

          1 所需依赖:

<dependency>
 <groupId>org.springframework.boot</groupId>
 <artifactId>spring-boot-starter-amqp</artifactId>
</dependency>

       2  加载交换机,队列,到容器,并绑定。

/**
 * 初始化Fanout交换机和队列,并将其绑定
 * */
@Configuration
public class FanoutConfig {

    // 初始化创建交换机
    @Bean
    public Fanout
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值