------------------------------------------------

开发一个JMS的基本步骤如下:

  1.创建一个JMS connection factory

  2.通过connection factory来创建JMS connection

  3.启动JMS connection

  4.通过connection创建JMS session

  5.创建JMS destination

  6.创建JMS producer 或者创建JMS message,并设置destination

  7.创建JMS consumer 或者注册一个JMS message listener

  8.发送或者接受JMS message

  9.关闭所有的JMS资源(connection、session、producer、consumer等)

可以参考下图:

非持久的Topic消息示例

  对于非持久化的消息,当发送方发送消息的时候:

    如果接收方不在线,则接收方永远也收不到这些消息了

    如果接收方在线,则接收方会收到这些消息

1、消息发送程序

 import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.MessageProducer;
import javax.jms.Session;
import javax.jms.TextMessage; import org.apache.activemq.ActiveMQConnectionFactory; /**
* 非持久化Topic消息发送者
* @author Administrator
*
*/
public class NoPersistenceSender {
public static void main(String[] args) throws Exception {
//创建一个JMS connection factory
ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://192.168.1.81:61616");
//通过connection factory来创建JMS connection
Connection connection = connectionFactory.createConnection();
//启动JMS connection
connection.start();
//通过connection创建JMS session
Session session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);
//创建JMS destination
Destination destination = session.createTopic("noPersistenceTopic");
//创建JMS producer
MessageProducer producer = session.createProducer(destination);

for(int i = 0;i < 10;i++){
TextMessage message = session.createTextMessage("message-"+i);
//发送message
producer.send(message);
}
//关闭所有的JMS资源
session.commit();
session.close();
connection.close();
}
}

运行完消息发送程序后,可以访问192.168.1.81:8161

2、消息接收程序

  对于非持久的Topic消息的接收需要注意以下几点:

    a.接收程序必须在线,然后消息发送方再发送消息,接收程序才能接收到消息

    b.由于不知道消息发送方要发送多少条消息,所以利用while循环的方式来接收消息

    c.如果接收程序不在线,此时发送程序发送了消息的话,则该消息将永远不会被接收方收到。

 import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Destination;
import javax.jms.Message;
import javax.jms.MessageConsumer;
import javax.jms.Session;
import javax.jms.TextMessage; import org.apache.activemq.ActiveMQConnectionFactory; /**
* 非持久化Topic消息接收者
* @author Administrator
*
*/
public class NoPersistenceReceiver {
public static void main(String[] args) throws Exception {
//创建一个JMS connection factory
ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://192.168.1.81:61616");
//通过connection factory来创建JMS connection
Connection connection = connectionFactory.createConnection();
//启动JMS connection
connection.start();
//通过connection创建JMS session
Session session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);
//创建JMS destination
Destination destination = session.createTopic("noPersistenceTopic");
//创建JMS consumer
MessageConsumer consumer = session.createConsumer(destination);

Message message = consumer.receive();
while(message != null){
TextMessage txtMsg = (TextMessage)message;
System.out.println("收到消息:"+txtMsg.getText());
message = consumer.receive();
}
//关闭所有的JMS资源
session.commit();
session.close();
connection.close();
}
}

运行结果:

持久的Topic消息示例

1.消息发送程序

  对于持久的Topic消息的发送方需要注意以下几点:

    a.要用持久化订阅,发送消息者要用DeliveryMode.PERSISTENT模式来发送

 import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.DeliveryMode;
import javax.jms.Destination;
import javax.jms.MessageProducer;
import javax.jms.Session;
import javax.jms.TextMessage; import org.apache.activemq.ActiveMQConnectionFactory; /**
* 持久化Topic消息发送者
* @author Administrator
*/
public class PersistenceSender {
public static void main(String[] args) throws Exception {
//创建一个JMS connection factory
ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://192.168.1.81:61616");
//通过connection factory来创建JMS connection
Connection connection = connectionFactory.createConnection();
//通过connection创建JMS session
Session session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);
//创建JMS destination
Destination destination = session.createTopic("PersistenceTopic");
//创建JMS producer
MessageProducer producer = session.createProducer(destination);
producer.setDeliveryMode(DeliveryMode.PERSISTENT);
//启动JMS connection
connection.start();
for(int i = 0;i < 10;i++){
TextMessage message = session.createTextMessage("message-"+i);
//发送message
producer.send(message);
}
//关闭所有的JMS资源
session.commit();
session.close();
connection.close();
}
}

2.消息接收程序

  对于持久的Topic消息的接收方需要注意以下几点:

    a.需要在连接上设置消费者id,用来识别消费者

    b.需要创建TopicSubscriber来订阅

    c.一定要先运行一次该消费者程序,等于向消费服务中间件注册这个消费者,然后再运行消息发送者来发送消息,这样的话,无论消费者是否在线都会收到消息,如果不在线的话,则下次连接的时候会把没有收过的消息都接收下来。

 import javax.jms.Connection;
import javax.jms.ConnectionFactory;
import javax.jms.Message;
import javax.jms.Session;
import javax.jms.TextMessage;
import javax.jms.Topic;
import javax.jms.TopicSubscriber; import org.apache.activemq.ActiveMQConnectionFactory; /**
* 持久化Topic消息接收者
* @author Administrator
*
*/
public class PersistenceReceiver {
public static void main(String[] args) throws Exception {
//创建一个JMS connection factory
ConnectionFactory connectionFactory = new ActiveMQConnectionFactory("tcp://120.76.123.81:61616");
//通过connection factory来创建JMS connection
Connection connection = connectionFactory.createConnection();
connection.setClientID("con1");
//通过connection创建JMS session
Session session = connection.createSession(Boolean.TRUE, Session.AUTO_ACKNOWLEDGE);
//创建JMS destination
Topic destination = session.createTopic("PersistenceTopic");
//创建JMS consumer
TopicSubscriber ts = session.createDurableSubscriber(destination, "TT");
//启动JMS connection
connection.start();
Message message = ts.receive();
while(message != null){
TextMessage txtMsg = (TextMessage)message;
session.commit();
System.out.println("收到消息:"+txtMsg.getText());
message = ts.receive(1000L);
}
//关闭所有的JMS资源
session.close();
connection.close();
}
}

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

有两种方式指定传送模式:

  1.使用setDeliveryMode方法,这样所有的消息都采用此传送模式;如producer.setDeliveryMode(DeliveryMode.NON_PERSISTENT)

  2.使用send方法为每条消息设置传送模式

持久化消息

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

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

非持久化消息

  保证这些消息最多被传送一次。对于这些消息,可靠性并非主要的考虑因素。此模式并不要求持久性的数据存储,也不保证消息服务由于某种原因导致失败后消息不会丢失。

  

JMS开发步骤和持久化/非持久化Topic消息的更多相关文章

  1. JMS学习(五)--ActiveMQ中的消息的持久化和非持久化 以及 持久订阅者 和 非持久订阅者之间的区别与联系

    一,消息的持久化和非持久化 ①DeliveryMode 这是传输模式.ActiveMQ支持两种传输模式:持久传输和非持久传输(persistent and non-persistent deliver ...

  2. ActiveMQ学习笔记(4)----JMS的API结构和开发步骤

    1. JMS的API结构 其实上图中的五个API在第一节中我们都已经使用到了.本节将会讲非持久化和持久化topic的使用. 2. JMS的基本开发步骤 1. 创建一个JMS工厂,  Connectio ...

  3. redisd的非持久化配置

    如何关闭redis持久化?我的需求是只把redis当作缓存来用,所以持久化到硬盘对我的需求来说没有意义. 修改redis配置文件,redis.conf 第115行左右. 1.注释掉原来的持久化规则 # ...

  4. RabbitMQ学习笔记(6)----RabbitMQ 持久化和非持久化

    持久化:将交换机或队列数据保存到磁盘,服务器宕机或重启之后依然存在. 非持久化:将交换机或队列的数据保存到内存中,服务器宕机或重启之后数据将不存在. 在RabbitMQ中也提供了持久化和非持久化方式. ...

  5. RabbitMQ持久化和非持久化

    但是,非持久化要比持久化速度更快. 队列是否需要持久化:看需求

  6. JMS开发指南

    1.JMS消息的异步与同步接收 消息的异步接收: 异步接收是指当消息到达时,主动通知客户端,即当消息到达时转发到客户端.JMS客户端可以通过注册一个实现MessageListener接口的对象到Mes ...

  7. iOS应用内付费(IAP)开发步骤列表

    iOS应用内付费(IAP)开发步骤列表 前两天和服务端同事一起,完成了应用内付费(以下简称IAP, In app purchase)的开发工作.步骤繁多,在此把开发步骤列表整理如下.因为只是步骤列表, ...

  8. 以DDD为开发模式的设计开发步骤可以是

    以DDD为开发模式的设计开发步骤可以是:1)分析需求:2)画出用例图,系统中各个角色如何使用系统,也包括外部系统如何使用系统,也包括系统中到某个时间点自动启动的某些功能(此时角色就是时间):3)针对各 ...

  9. Lind.DDD.LindMQ~关于持久化到Redis的消息格式

    回到目录 关于持久化到Redis的消息格式,主要是说在Broker上把消息持久化的过程中,需要存储哪些类型的消息,因为我们的消息是分topic的,而每个topic又有若干个queue组成,而我们的to ...

随机推荐

  1. linux中inode、软链接、硬链接

    1 软链接 linux中软链接理解成window中的快捷方式.创建软链接的命令 ln -s 源文文件或目录 目标文件或目录 2 硬链接 创建硬链接的命令如下 ln  源文文件或目录 目标文件或目录 3 ...

  2. 【转载】Linux 文件系统的目录结构

    /bin 基础系统所需要的那些命令位于此目录,也是最小系统所需要的命令:比如 ls.cp.mkdir等命令:功能和/usr/bin类似,这个目录中的文件都是可执行的,普通用户都可以使用的命令.做为基础 ...

  3. Machine Learning Algorithms Study Notes(5)—Reinforcement Learning

    Reinforcement Learning 对于控制决策问题的解决思路:设计一个回报函数(reward function),如果learning agent(如上面的四足机器人.象棋AI程序)在决定 ...

  4. 洛谷P3390 【模板】矩阵快速幂

    给定n*n的矩阵A,求A^k 行列都是n #include <iostream> #include <cstdio> #include <cstring> #inc ...

  5. SQL语句的使用

    SELECT b.level, a.cnt FROM  (SELECT `level`,COUNT(*) AS cnt FROM wlsjlog GROUP BY level) a LEFT JOIN ...

  6. HttpClient

    Http协议的重要性相信不用我多说了,HttpClient相比传统JDK自带的URLConnection,增加了易用性和灵活性(具体区别,日后我们再讨论),它不仅是客户端发送Http请求变得容易,而且 ...

  7. AI方向

    普通程序员如何转向AI方向   眼下,人工智能已经成为越来越火的一个方向.普通程序员,如何转向人工智能方向,是知乎上的一个问题.本文是我对此问题的一个回答的归档版.相比原回答有所内容增加. 一. 目的 ...

  8. <转>卷积神经网络是如何学习到平移不变的特征

    After some thought, I do not believe that pooling operations are responsible for the translation inv ...

  9. .Net配置中心-简介

    系统简介 最近做了一个.Net配置中心,本质就是将原本放在各个站点下AppSettings中的配置统一管理,可以实现一次更改,自动更新,这里提供了两个版本, 一个是心跳版,一个是zookeeper版. ...

  10. RSVP协议的基本概念介绍

    2010-06-12 14:12 佚名 互联网 字号:T | T 对于RSVP协议的简单介绍和图解.通过文章,我们将对这个含义的基本概念和结构,以及工作方式等方面的知识有所了解.希望对大家有所帮助. ...