RabbitMQ的使用(可以实现商品数据的同步)

1.1. 安装完成后操作
1、系统服务中有RabbitMQ服务,停止、启动、重启
这里写图片描述

1、 打开命令行工具

这里写图片描述
如果找不到命令行工具:
这里写图片描述
2、 启用管理插件
这里写图片描述
3、 查看管理页面
这里写图片描述
4、 通过默认账户 guest/guest 登录
如果能够登录,说明安装成功。
这里写图片描述
1.2. 添加用户
这里写图片描述

1.3. 管理界面中的功能

这里写图片描述

这里写图片描述

  1. 5种队列
    [外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-6dHjFpKJ-1573631996723)(https://img-blog.csdn.net/20170719110638214?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvTEVPTl9OSVVCSQ==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)]

1.1. 简单队列
1.1.1. 图示
这里写图片描述

P:消息的生产者
C:消息的消费者
红色:队列

生产者将消息发送到队列,消费者从队列中获取消息。
1.1.2. 导入RabbitMQ的客户端依赖
这里写图片描述

1.1.3. 获取MQ的连接

这里写图片描述
1.1.4. 生产者发送消息到队列
这里写图片描述

1.1.5. 管理工具中查看消息
这里写图片描述

点击上面的队列名称,查询具体的队列中的信息:

1.1.1. 消费者从队列中获取消息

这里写图片描述

1.1. Work模式

这里写图片描述

1.1.1. 图示
这里写图片描述

一个生产者、2个消费者。

一个消息只能被一个消费者获取。
1.1.2. 消费者1
public class Recv {

private final static String QUEUE_NAME = "test_queue_work";

public static void main(String[] argv) throws Exception {

    // 获取到连接以及mq通道
    Connection connection = ConnectionUtil.getConnection();
    Channel channel = connection.createChannel();

    // 声明队列
    channel.queueDeclare(QUEUE_NAME, false, false, false, null);

    // 同一时刻服务器只会发一条消息给消费者
    //channel.basicQos(1);

    // 定义队列的消费者
    QueueingConsumer consumer = new QueueingConsumer(channel);
    // 监听队列,手动返回完成
    channel.basicConsume(QUEUE_NAME, false, consumer);

    // 获取消息
    while (true) {
        QueueingConsumer.Delivery delivery = consumer.nextDelivery();
        String message = new String(delivery.getBody());
        System.out.println(" [x] Received '" + message + "'");
        //休眠
        Thread.sleep(10);
        // 返回确认状态
        channel.basicAck(delivery.getEnvelope().getDeliveryTag(), false);
    }
}

}

1.1.3. 消费者2
public class Recv2 {

private final static String QUEUE_NAME = "test_queue_work";

public static void main(String[] argv) throws Exception {

    // 获取到连接以及mq通道
    Connection connection = ConnectionUtil.getConnection();
    Channel channel = connection.createChannel();

    // 声明队列
    channel.queueDeclare(QUEUE_NAME, false, false, false, null);

    // 同一时刻服务器只会发一条消息给消费者
    //channel.basicQos(1);

    // 定义队列的消费者
    QueueingConsumer consumer = new QueueingConsumer(channel);
    // 监听队列,手动返回完成状态
    channel.basicConsume(QUEUE_NAME, false, consumer);

    // 获取消息
    while (true) {
        QueueingConsumer.Delivery delivery = consumer.nextDelivery();
        String message = new String(delivery.getBody());
        System.out.println(" [x] Received '" + message + "'");
        // 休眠1秒
        Thread.sleep(1000);

        channel.basicAck(delivery.getEnvelope().getDeliveryTag(), false);
    }
}

}

1.1.4. 生产者
向队列中发送50条消息。

这里写图片描述

1.1.5. 测试
测试结果:
1、 消费者1和消费者2获取到的消息内容是不同的,同一个消息只能被一个消费者获取。
2、 消费者1和消费者2获取到的消息的数量是相同的,一个是奇数一个是偶数。

其实,这样是不合理的,应该是消费者1要比消费者2获取到的消息多才对。

1.1. Work模式的“能者多劳”
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-0Msch3LA-1573631996726)(https://img-blog.csdn.net/20170719111602357?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvTEVPTl9OSVVCSQ==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)]

测试:
消费者1比消费者2获取的消息更多。

1.1. 消息的确认模式
消费者从队列中获取消息,服务端如何知道消息已经被消费呢?

模式1:自动确认
只要消息从队列中获取,无论消费者获取到消息后是否成功消息,都认为是消息已经成功消费。
模式2:手动确认
消费者从队列中获取消息后,服务器会将该消息标记为不可用状态,等待消费者的反馈,如果消费者一直没有反馈,那么该消息将一直处于不可用状态。

手动模式:

这里写图片描述

自动模式:
这里写图片描述
1.1. 订阅模式
这里写图片描述

1.1.1. 图示
这里写图片描述

解读:
1、1个生产者,多个消费者
2、每一个消费者都有自己的一个队列
3、生产者没有将消息直接发送到队列,而是发送到了交换机
4、每个队列都要绑定到交换机
5、生产者发送的消息,经过交换机,到达队列,实现,一个消息被多个消费者获取的目的

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-z3s5PpJL-1573631996727)(https://img-blog.csdn.net/20170719112411285?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvTEVPTl9OSVVCSQ==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)]

1.1.2. 消息的生产者(看作是后台系统)
向交换机中发送消息。

这里写图片描述

注意:消息发送到没有队列绑定的交换机时,消息将丢失,因为,交换机没有存储消息的能力,消息只能存在在队列中。
1.1.3. 消费者1(看作是前台系统)

[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-WQK5cmWX-1573631996728)(https://img-blog.csdn.net/20170719112447787?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvTEVPTl9OSVVCSQ==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)]
1.1.4. 消费者2(看作是搜索系统)

这里写图片描述
1.1.5. 测试
测试结果:
同一个消息被多个消费者获取。

在管理工具中查看队列和交换机的绑定关系:
这里写图片描述
路由模式

这里写图片描述

这里写代码片

1.1.1. 图示
这里写图片描述

1.1.2. 生产者

这里写图片描述
1.1.3. 消费者1(前台系统)

这里写图片描述
1.1.4. 消费2(搜索系统)
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-UGklZJPN-1573631996731)(https://img-blog.csdn.net/20170719112738986?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvTEVPTl9OSVVCSQ==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)]
1.1. 通配符模式

这里写图片描述

这里写图片描述

1.1.1. 图示
这里写图片描述

1.1.2. 生产者
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-JK48AABW-1573631996733)(https://img-blog.csdn.net/20170719112845618?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvTEVPTl9OSVVCSQ==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)]

1.1.3. 消费者1(前台系统)
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-3LnXsSGw-1573631996733)(https://img-blog.csdn.net/20170719112854012?watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvTEVPTl9OSVVCSQ==/font/5a6L5L2T/fontsize/400/fill/I0JBQkFCMA==/dissolve/70/gravity/SouthEast)]

1.1.4. 消费者2(搜索系统)
这里写图片描述

  • 4
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值