RabbitMQ介绍及简单操作

文章目录

一、同步调用

例如:
支付服务 1.用户登录 2.交易服务 3.通知服务 4.积分服务

通过openfeign进行服务之间通信实现商城的支付服务,需要用户登录、交易服务、通知服务、积分服务,四个服务缺一不可。

每一个服务都不能出现问题,一旦出现问题就会影响性能,甚至报错中断。

openfeign同步调用:

  • 优势:时效性强,等待结果后返回
  • 缺点:拓展性差
  • 缺点:性能下降
  • 缺点:级联失败问题

二、异步调用

支付服务通过异步的方式调用业务关联度降低,发送消息通知到Broker。

例如:
发送消息通知 发送消息通知 支付服务 1.用户登录 2.交易服务 消息代理 通知服务 积分服务

优势:

  • 解耦,拓展性强
  • 无需等待,性能好
  • 故障隔离
  • 缓存消息,流量削峰填谷
    缺点:
  • 实时性差
  • 不确定下游业务是否执行成功
  • 业务安全依赖于Broker(消息代理)的可靠性

三、MQ介绍

MQ(消息队列),存放消息的队列,异步调用中的Broker,先进先出(FIFO)。

Kafka每秒吞吐量达百万级;

RockertMQ每秒吞吐量达十万级;

RabbitMQ每秒吞吐量达十万级左右,但是它消息延迟仅仅是微秒的,可靠性高;

考虑大部分情况下公司是达不到每秒吞吐量百万级的,所以选择RabbitMQ。
RabbitMQ官网

1.安装RabbitMQ

BASH 复制代码
docker run -d -p 15672:15672  -p  5672:5672  -e RABBITMQ_DEFAULT_USER=admin -e RABBITMQ_DEFAULT_PASS=admin --name rabbitmq --hostname=rabbitmqhostone  rabbitmq

下载rabbitmq并且启动成功之后,可以直接访问http://localhost:15672,用户名密码都是admin

2.介绍RabbitMQ

RabbitMQ整体架构及核心概念:

  • publisher:消息发送者
  • exchange:交换机,负责路由消息
  • queue:队列,存储消息
  • consumer:消息的消费者
  • virtual-host:虚拟主机,起到数据隔离的作用

3.页面简单使用

  1. 登录

  2. 创建用户

  3. 创建exchange,我创建的是test

  4. 创建queue

  5. 将exchange和queue关联起来,关联可以在queues中操作,也可以在exchanges中操作

  6. 测试发送消息

  • 进入exchange搜索我们创建的exchange
  • 点击Name,可以进入详情页,查看到绑定的queue,可以发送消息
  • 发送消息之后可以看到有发送的记录数据
  • 进去queue页面可以看到通过exchange发送消息的队列中有了1条消息
  • 点击Name进入详情,可以查看消息内容
相关推荐
深蓝电商API7 小时前
分布式事务在跨境交易中的解决方案
分布式·跨境电商·代购系统·反向海淘·代购平台·跨境代购
我真会写代码12 小时前
从入门到精通:Kafka核心原理与实战避坑指南
分布式·缓存·kafka
黄俊懿13 小时前
【架构师从入门到进阶】第二章:系统衡量指标——第一节:伸缩性、扩展性、安全性
分布式·后端·中间件·架构·系统架构·架构设计
一叶飘零_sweeeet13 小时前
击穿 Kafka 高可用核心:分区副本、ISR 机制与底层原理全链路拆解
分布式·架构·kafka
007张三丰15 小时前
常用缓存技术全方位解析:从本地缓存到分布式缓存
分布式·缓存
tianyuanwo18 小时前
Koji 分布式编译调度机制深度解析:多架构异构节点的资源优化方案
分布式·架构
江沉晚呤时19 小时前
.NET 9 快速上手 RabbitMQ 直连交换机:高效消息传递实战指南
开发语言·分布式·后端·rabbitmq·.net·ruby
Volunteer Technology19 小时前
zookeeper基础应用与实战二
分布式·zookeeper·云原生
姚青&21 小时前
Pytest 测试用例并行运行与分布式运行
分布式·测试用例·pytest
若水不如远方2 天前
分布式一致性(六):拥抱可用性 —— 最终一致性与 Gossip 协议
分布式·后端·算法