消息中间件基础

消息中间件简介

什么是消息中间件

消息队列中间件 (Message Queue Middleware,简称为 MQ) 是指利用高效可靠的消息传递机制进行与平台无关的数据交流,并基于数据通信来进行分布式系统的集成。通过提供消息传递和消息排队模型,它可以在分布式环境下扩展进程间的通信。提供了以松散藕合的灵活方式集成应用程序的一种机制。它们提供了基于存储和转发的应用程序之间的异步数据发送,即应用程序彼此不直接通信,而是与作为中介的消息中间件通信。消息中间件提供了有保证的消息发送,应用程序开发人员无须了解远程过程调用 ( RPC) 和网络通信协议的细节。
在这里插入图片描述

消息中间件的作用

异步(解决不必要的阻塞):消息中间件提供了异步处理机制,允许应用把一些消息放入消息中间件中,但并不立即处理它,在之后需要的时候在慢慢处理。
解耦(降低模块间的耦合关系):消息中间件在处理过程中间插入了一个隐含的、基于数据的接口层。
削峰(峰值任务的平滑处理):在访问剧增的情况下,应用仍然需要继续发挥作用。
冗余(存储,补偿机制):有些情况下,处理数据的过程会失败。消息中间件可以把数据持久化直到它们已经被完全处理,通过这一方式规避了数据丢失风险。

JMS规范与AMQP协议

JMS规范

JMS(Java Message Service)规范本质上是一套API,只适用于Java平台的消息中间件规范,支持Java应用程序之间进行消息交换。并且通过提供标准的生产、发送、接收消息的接口简化企业应用的开发。
在这里插入图片描述
JSM规范支持的消息类型:Text、Map、Object、Bytes、Stream
JSM消息模型:

  1. 点对点
    在这里插入图片描述
  2. 发布订阅
    在这里插入图片描述

AMQP协议

AMQP协议是一套开放标准,支持不同语言的不同产品。

AMQP组件

生产者:消息的创建者,将消息发送到消息中间件
消费者:连接到消息中间件上,订阅在队列上,进行消息的消费。
消息:包括有效载荷与标签。有效载荷:要传输的数据;标签:描述有效载荷的属性;RabbitMQ通过标签决定谁获得该消息,消费者只能得到有效载荷。
信道:可理解为一个虚拟的连接,建立在真实的TCP/IP连接之上。所有AMQP上的消息都通过信道传输,TCP/IP连接的建立和释放 对服务器有很大的消耗、昂贵的资源。信道的创建没有数量限制,保护资源的利用。
交换器、队列、绑定、路由键:队列通过路由键(routing key)绑定到交换器,生产者把消息发送到交换器,交换器根据绑定的路由键把消息路由到特定的队列中,再由订阅该队列的消费者进行消息的消费。
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值