分布式-5-JMS

JMS(Java Message Service)

  • API规范
  • 模式
    • 点对点
    • 发布订阅

点对点

  • 组成
    • 消息队列(Queue)
    • 发送者(Sender)
    • 接收者(Receiver)
    • 每个消息都被发送到一个特定队列,接收者从队列获取消息
    • 队列保留着消息,直到他们被消费或超时
  • 特点
    • 每个消息只有一个消费者
    • 发送者和接收者时间上没有依赖,接收者运行与否,不会影响消息被发送到队列
    • 接收者成功收消息后需向队列应答
  • 场景
    • 如果你希望发送的每个消息都应该被成功处理的话,那么你需要P2P模式

发布订阅

  • 组成
    • 主题(Topic)
    • 发布者(Publisher)
    • 订阅者(Subscriber)
    • 发布者将消息发送到Topic,系统将消息传递给多个订阅者
  • 特点
    • 每个消息可以有多个消费者
    • 发布者和订阅者有时间上的依赖
    • 针对某个主题(Topic),为了消费消息,订阅者必须保持运行的状态
    • 为了缓和严格的时间相关性,JMS允许订阅者创建可持久化订阅;这样,即使订阅者没有被激活(运行),也能接收到发布者的消息
  • 场景
    • 如果希望发送的消息可以不被做任何处理、或被一个消费者处理、或可以被多个消费者处理的话,那么可以采用Pub/Sub模型

消费消息

  • JMS中,消息的产生和消费是异步的
  • 消费端而言,则有同步和异步2种
    • 同步
      • 消费者调用receive方法接收消息,接收到消息之前(或超时之前)将一直阻塞
    • 异步
      • 消费者注册为消息监听器;消息到达后,系统自动调用监听器的onMessage方法

JMS编程模型

  • ConnectionFactory
    • QueueConnectionFactory
    • TopicConnectionFactory
  • Destination
    • Queue
    • Topic
  • Connection
    • 对socket的包装,可产生1到多个session
    • QueueConnection
    • TopicConnection
  • Session
    • 可以创建生产者,消费者,消息
    • 有事务功能,可将多个消息动作放在一起
    • QueueSession
      • createReceiver(Queue)
    • TopicSession
      • createSubscriber(Topic)
      • creatDurableSubscriber
  • 生产者
    • QueueSender.send
    • TopicPublisher.publish
  • 消费者
    • QueueReceiver
    • TopicSubscriber
  • MessageListener
    • 消息监听器
    • 若注册了消息监听器,一旦消息到达,将自动调用监听器的onMessage方法
    • EJB中的MDB(Message-Driven Bean)就是一种MessageListener

消息中间件

  • MOM,Message Orient Middleware
  • 用途和优点
    • 应用间传递数据
    • 建立网络通信通道,进行数据可靠传送
    • 保证数据不重发,不丢失
    • 跨平台,能够为不同操作系统上的软件集成提供数据传送

AMQP(Advanced Message Queuing Protocol)

  • AMQP是一种协议,而JMS是一种API规范
  • 消息服务应用层协议,基于此协议的客户端和消息中间件可传递消息,不受产品和开发语言等限制
  • RabbitMQ是AMQP的一个完整实现
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • http://liuxing.info/2017/06/30/Spring%20AMQP%E4%B8%AD%E6%...
    sherlock_6981阅读 16,157评论 2 11
  • 以下是消息队列以下的大纲,本文主要介绍消息队列概述,消息队列应用场景和消息中间件示例(电商,日志系统)。 本次分享...
    文档随手记阅读 5,858评论 0 28
  • 1 消息队列概述 消息队列中间件是分布式系统中重要的组件,主要解决应用耦合,异步消息,流量削锋等问题。实现高性能,...
    Bobby0322阅读 13,722评论 0 24
  • 一、 消息队列概述 消息队列中间件是分布式系统中重要的组件,主要解决应用耦合、异步消息、流量削锋等问题。实现高性能...
    步积阅读 57,302评论 10 138
  • 一、JMS是个什么 JMS即Java消息服务(Java Message Service)应用程序接口,是一个Jav...
    LynnGuo阅读 4,256评论 0 6

友情链接更多精彩内容