(七十)java版spring cloud+spring boot+redis多租户社交电子商务平台-消息队列之ActiveMQ

电子商务平台源码请加企鹅求求:三伍三六贰四柒二伍九。什么是ActiveMQ?服务器

ActiveMQ 是Apache出品,最流行的,能力强劲的开源消息总线。ActiveMQ 是一个彻底支持JMS1.1和J2EE 1.4规范的 JMS Provider实现,尽管JMS规范出台已是好久的事情了,可是JMS在当今的J2EE应用中间仍然扮演着特殊的地位。ide

主要特色:性能

多种语言和协议编写客户端。语言: Java, C, C++, C#, Ruby, Perl, Python, PHP。应用协议: OpenWire,Stomp REST,WS Notification,XMPP,AMQP 彻底支持JMS1.1和J2EE 1.4规范 (持久化,XA消息,事务)测试

对Spring的支持,ActiveMQ能够很容易内嵌到使用Spring的系统里面去,并且也支持Spring2.0的特性设计

经过了常见J2EE服务器(如 Geronimo,JBoss 4, GlassFish,WebLogic)的测试,其中经过JCA 1.5 resource adaptors的配置,可让ActiveMQ能够自动的部署到任何兼容J2EE 1.4 商业服务器上 支持多种传送协议:in-VM,TCP,SSL,NIO,UDP,JGroups,JXTA对象

支持经过JDBC和journal提供高速的消息持久化队列

从设计上保证了高性能的集群,客户端-服务器,点对点事务

支持Ajax字符串

支持与Axis的整合部署

能够很容易得调用内嵌JMS provider,进行测试

ActiveMQ的消息形式:

对于消息的传递有两种类型:

一种是点对点的,即一个生产者和一个消费者一一对应;

另外一种是发布/订阅模式,即一个生产者产生消息并进行发送后,能够由多个消费者进行接收。

JMS定义了五种不一样的消息正文格式,以及调用的消息类型,容许你发送并接收以一些不一样形式的数据,提供现有消息格式的一些级别的兼容性。

  · StreamMessage – Java原始值的数据流

  · MapMessage–一套名称-值对

  · TextMessage–一个字符串对象

  · ObjectMessage–一个序列化的 Java对象

  · BytesMessage–一个字节的数据流    ActiveMQ消息确认机制

消息只有在被确认以后,才认为已经被成功消费,而后消息才会从队列或主题中删除。消息的成功消费一般包含三个阶段:

(1)、客户接收消息;(2)、客户处理消息;(3)、消息被确认;

确认机制前面提过一下,共有四种:

(1)、Session.AUTO_ACKNOWLEDGE;客户(消费者)成功从receive方法返回时,或者从MessageListener.onMessage方法成功返回时,会话自动确认消息,而后自动删除消息.

(2)、Session.CLIENT_ACKNOWLEDGE;客户经过显式调用消息的acknowledge方法确认消息,。 即在接收端调用message.acknowledge();方法,不然,消息是不会被删除的.

(3)、Session. DUPS_OK_ACKNOWLEDGE ;不是必须确认,是一种“懒散的”消息确认,消息可能会重复发送,在第二次从新传送消息时,消息头的JMSRedelivered会被置为true标识当前消息已经传送过一次,客户端须要进行消息的重复处理控制。

(4)、 Session.SESSION_TRANSACTED;事务提交并确认。

相关文章
相关标签/搜索