分布式服务-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的一个完整实现
  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Eddy咸鱼

感谢大佬加鸡蛋~

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值