关于持久化和非持久化消息

                               关于持久化和非持久化消息

持久化消息

持久化消息是 ActiveMQ 的默认传送模式,此模式保证这些消息只被传送一次和成功使用一次。对于这些消息,可靠性是优先考虑的因素。可靠性的另一个重要方面是确保持久性消息传送至目标后,消息服务在向消费者传送它们之前不会丢失这些消息。

这意味着在持久性消息传送至目标时,消息服务将其放入持久性数据存储。如果消息服务由于某种原因导致失败,它可以恢复此消息并将此消息传送至相应的消费者。虽然这样增加了消息传送的开销,但却增加了可靠性。

持久的Topic消息示例

   持久的Topic消息发送

  • 要用持久化订阅,发送者要在连接之前设定 DeliveryMode.PERSISTENT 模式发送。
  • 一定要设置完成后,再start 这个 connection 。
       ConnectionFactory connectionFactory = new 
     ActiveMQConnectionFactory("tcp://192.168.1.106:61616");
    	Connection connection = connectionFactory.createConnection();
    	Session session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);
    	Topic destination = session.createTopic("MyTopic");
    	MessageProducer producer = session.createProducer(destination);
    	producer.setDeliveryMode(DeliveryMode.PERSISTENT);
    	connection.start();
    	TextMessage message = session.createTextMessage("messagedd");
    	//通过消息生产者发出消息
    	producer.send(message);
    	session.commit();
    	session.close();
    	connection.close(); 

    持久的Topic消息发送

  • 需要在连接上设置消费者id,用来识别消费者。
  • 需要创建TopicSubscriber来订阅。
  • 要设置好了过后再start 这个 connection。
  • 一定要先运行一次,等于向消息服务中间件注册这个消费者,然后再运行客户端发送信息,这个时候,无论消费者是否在线,都会接收到,不在线的话,下次连接的时候,会把没有收过的消息都接收下来。 
ConnectionFactory cf = new ActiveMQConnectionFactory("tcp://192.168.1.106:61616");
	Connection connection = cf.createConnection();
	connection.setClientID("cc1");
	final Session session = connection.createSession(Boolean.TRUE, 	Session.AUTO_ACKNOWLEDGE);
	Topic destination = session.createTopic("MyTopic");
	TopicSubscriber ts = session.createDurableSubscriber(destination, "T1");
	connection.start();
	Message message = ts.receive();
	while(message!=null) {
		TextMessage txtMsg = (TextMessage)message;
		session.commit();
		System.out.println("收到消 息:" + txtMsg.getText());
		message = ts.receive(1000L);
	}
	session.close();
	connection.close(); 

 非持久的Topic消息示例

对于非持久的Topic消息的发送基本跟前面发送队列信息是一样的,只是把创建Destination的地方,由创建队列替换成创建Topic,例如:

非持久的Topic消息的接收

  1. 必须要接收方在线,然后客户端再发送信息,接收方才能接收到消息。
  2. 同样把创建Destination的地方,由创建队列替换成创建Topic。
  3. 由于不知道客户端发送多少信息,因此改成while循环的方式了,例如:
Message message = consumer.receive();
while(message!=null) {
	TextMessage txtMsg = (TextMessage)message;
	System.out.println("收到消息:" + txtMsg.getText());
	message = consumer.receive(1000L);
} 

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值