一、理解JMS
1、什么是JMS?
JMS即Java消息服务(Java Message Service)应用程序接口,API是一个消息服务的标准或者说是规范,允许应用程序组件基于JavaEE平台创建、发送、接收和读取消息。它使分布式通信耦合度更低,消息服务更加可靠以及异步性。
我们可以简单的理解:两个应用程序之间需要进行通信,我们使用一个JMS服务,进行中间的转发,通过JMS 的使用,我们可以解除两个程序之间的耦合。
JMS不是消息队列,更不是某种消息队列协议。JMS是Java消息服务接口,是一套规范的JAVA API 接口。
1)这套规范接口由SUN提出,并在2002年发布JMS规范的Version 1.1版本。
2)JMS和消息中间件厂商无关,既然是一套接口规范,就代表这它需要各个厂商进行实现。
3)大部分消息中间件产品都支持JMS 接口规范,eg: 可以使用JMS API来连接Stomp协议的产品(例如ActiveMQ)。
就像您可以使用JDBC API来连接ORACLE或者MYSQL一样。
2、JMS的消息模型
JMS具有两种通信模式:(点对点)和(发布/订阅模式)。
3、JMS中消息的产生和消费
在JMS中,消息的产生和消息是异步的。对于消费来说,JMS的消息者可以通过两种方式来消费消息。
○ 同步 :订阅者或接收者调用receive方法来接收消息,receive方法在能够接收到消息之前(或超时之前)将一直阻塞
○ 异步 :订阅者或接收者可以注册为一个消息监听器。当消息到达之后,系统自动调用监听器的onMessage方法。
<