消息中间件介绍

什么是中间件

  • 非底层的操作系统软件,非应用 软件,不是直接给用户使用的,不能直接给用户带来价值的软件统称为中间件

什么是消息中间件

  • 关注于数据的发送和接受,利用高效可靠的异步消息传递机制集成分布式系统

消息中间件图示

消息中间件介绍

JMS与AMQP

什么是JMS

  • Java消息服务(Java message service),是一个Java平台中关于面向消息中间的API,用于在两个应用程序之间或者分布式系统中发布消息,进行异步通信

什么是AMQP

  • AMQP(advanced message queuing protocol)是一个提供统一消息服务的应用层标准协议,基于此协议的客户端与消息中间件可传递消息,并不受客户端、中间件不同产品,不同开发语言的限制
  • 对比:消息中间件介绍

常见的消息中间件的对比

ActiveMQ

  • ActiveMQ是Apache出品,最流行的,能力强劲的开源消息总栈,ActiveMQ是一个完全支持JMS1.1和J2EE1.4规范的JMS Provider实现,,尽管JMS规范出台已经是很久的事情了,但是JMS是在当今的J2EE应用中间仍然扮演着特殊的地位。
  • ActivieMQ特性
    • 多种语言和协议编写客户端
    • 完全支持JMS1.1和J2EE1.4规范(持久化,XA消息,事务)
    • 虚拟主题,组合目的,镜像队列
  • RabbitMQ
    • RabbitMQ是一个开源的AMQP实现,服务器端用Erlang语言编写,用户在分布式中存储转发消息,在易用性,扩展性,高可用性等方面表现不俗
    • 特性:
      • 支持多种客户端
      • AMQP的完整实现
      • 事务支持,发布确认
      • 消息持久化
  • Kafka
    • Kafka是一种高吞吐量的分布式发布订阅消息系统,是一个分布式的,分区的,可靠的分布式日志存储服务,他通过一种独一无二的设计提供了一个消息系统的功能
    • 特性:
      • 通过O的磁盘数据结构提供消息的持久化这种结构对于即使数以TB消息存储也能保持长时间的稳定性能
      • 高吞吐量:即使是非常普通的硬件Kafka也可以支持每秒数百万的消息
      • Partition.consumer group
        消息中间件介绍