activemq的高级特性之消息持久订阅 如果采用topic模式发送的时候,mq关闭了或消费者关闭了.在启动的时候,就会收不到mq发送的消息,所以就会出现消息持久订阅. 消息持久订阅:第一:消息要持久化.第二:订阅者要持久化. 1:消息持久化,修改发送端 messageProducer.setDeliveryMode(DeliveryMode.NON_PERSISTENT);     //mq的消息不会往数据库放 DeliveryMode.PERSISTENT //消息会持久化,默认值 2:订阅…
activemq的高级特性之通配符式分层订阅 队列的名称可以分层:aa.bb.cc.dd 可以匹配:aa.bb.cc.dd,aa.*.cc.dd,aa.> *:匹配当前层的内容 >:任何一层的都能匹配 已点分层…
activemq的高级特性之消息存储持久化 有基于文件的,数据库的,内存的.默认的是基于文件的,在安装目录/data/kahadb.在conf/activemq.xml文件中. <persistenceAdapter> <kahaDB directory="${activemq.data}/kahadb"/> </persistenceAdapter> 把存储持久化换成mysql的数据库. 1:修改配置文件 <persistenceAdapte…
activemq的高级特性之嵌入式activemq 1:编写activeMQ服务 import org.apache.activemq.broker.BrokerService; import org.apache.activemq.broker.jmx.ManagementContext; /** * 编写activemq的服务 */ public class EmbedMQ { public static void main(String[] args) throws Exception {…
高级特性之消息的可靠性 可靠性分为:生产者.消费者.生产者必须让mq收到消息,消费者必须能够接收到消息并且消费成功,这就是消息的可靠性. 1:生产者可靠性 Session session = connection.createSession(false, Session.AUTO_ACKNOWLEDGE); Session.AUTO_ACKNOWLEDGE是mq自动应答,当生产者往mq发送消息的时候,当模式为queue, 消息会自动的持久化,然后持久化之后就会通知发送者持久化成功,所以使用que…
消息的 destination 分为 queue 和 topic,而消费者称为 subscriber(订阅者).queue 中的消息只会发送给一个订阅者,而 topic 的消息,会发送给每一个订阅者.在 broker 中,处理 queue 消息和 topic 消息的逻辑是不同的.queue 先存储消息,然后把消息分发给消费者,topic 收到消息的同时,就会分发. Queue 中有 doMessageSend 和 iterate 方法,doMessageSend 负责接收生产者的消息,itera…
高级特性实战需求 当消费端是多个集群,集群A又包含多个服务. 当每个集群都要接受相同的一批消息,而集群内的每个服务都去分摊消息. 解决办法一:级联 增加一个中转者.但是不是特别的优化,而且性能也不是特别的好. 解决办法二: 1:虚拟主题 生产者 Destination destination = session.createTopic("VirtualTopic.vtgroup"); 生产者使用topic模式,VirtualTopic是固定的,vtrgroup是自定义的. 消费者 De…
1)什么是jms JMS即Java消息服务(Java Message Service)应用程序接口是一个Java平台中关于面向消息中间件(MOM)的API. 它便于消息系统中的Java应用程序进行消息交换,并且通过提供标准的产生.发送.接收消息的接口简化企业应用的开发, 翻译为Java消息服务. 2)体系架构 JMS由以下元素组成. JMS提供者provider:连接面向消息中间件的,JMS接口的一个实现.提供者可以是Java平台的JMS实现,也可以是 非Java平台的面向消息中间件的适配器.…
一.简介 Queue中的消息是按照顺序被分发到consumers的.然而,当你有多个consumers同时从相同的queue中提取消息时, 你将失去这个保证.因为这些消息是被多个线程并发的处理.有的时候,保证消息按照顺序处理是很重要的. 如,你可能不希望在插入订单操作结束之前执行更新这个订单的操作. 二.使用 ActiveMQ从4.x版本起开始支持Exclusive Consumer. Broker会从多个consumers中挑选一个consumer来处理queue中 所有的消息,从而保证了消息…
导读 最新在接触ActiveMQ,里面有个持久订阅者模块,功能是怎么样也演示不出来效果.配置参数比较简单(配置没几个参数),消费者第一次运行时,需要指定ClientID(此时Broker已经记录离线订阅者信息),在启动提供者,此时消息队列存在一条记录,然后在启动消费者,但是怎么样也获取不到消息,阿西吧~~~什么鬼,百度上一大堆,都是这样步骤,消费者端,指定以下ClientID就好了,可,想要的效果死活不出来...... 采坑之路 废话不多说,先上代码,后面再分析 消费者端代码 public vo…