首页 文章 精选 留言 我的

精选列表

搜索[网站开发],共10000篇文章
优秀的个人博客,低调大师

ActiveMQ(05):JMS的API结构、开发步骤与Topic

一、JMS的API结构 二、一个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(s) 9:关闭所有的JMS资源(connection, session, producer, consumer等) 三、topic 3.1 关于持久化和非持久化消息 持久化消息: 这是ActiveMQ的默认传送模式,此模式保证这些消息只被传送一次和成功使用一次。对于这些消息,可靠性是优先考虑的因素。 可靠性的另一个重要方面是确保持久性消息传送至目标后,消息服务在向消费者传送它们之前不会丢失这些消息。 这意味着在持久性消息传送至目标时,消息服务将其放入持久性数据存储。如果消息服务由于某种原因导致失败,它可以恢复 此消息并将此消息传送至相应的消费者。虽然这样增加了消息传送的开销,但却增加了可靠性。 非持久化消息: 保证这些消息最多被传送一次。对于这些消息,可靠性并非主要的考虑因素。 此模式并不要求持久性的数据存储,也不保证 消息服务由于某种原因导致失败后消息不会丢失。 有两种方法指定传送模式: 1.使用setDeliveryMode 方法,这样所有的消息都采用此传送模式; 如: producer.setDeliveryMode(DeliveryMode.NON_PERSISTENT); 2.使用send 方法为每一条消息设置传送模式 3.2 非持久的Topic消息 3.2.1 消息的发送 基本跟前面发送队列信息是一样的,只是把创建Destination的地方,由创建队列替换成创建Topic,例如: Destinationdestination=session.createTopic("my-topic"); 3.2.1 消息的接收 1:必须要接收方在线,然后客户端再发送信息,接收方才能接收到消息 2:同样把创建Destination的地方,由创建队列替换成创建Topic,例如: Destinationdestination=session.createTopic("my-topic"); 3:由于不知道客户端发送多少信息,因此改成while循环的方式了,例如: Messagemessage=consumer.receive(); while(message!=null){ TextMessagetxtMsg=(TextMessage)message; System.out.println("收到消息:"+txtMsg.getText()); message=consumer.receive(1000L); } 3.3持久的Topic消息 3.3.1 消息的发送 /**持久的*/ publicvoidtest2()throwsException{ ConnectionFactoryconnectionFactory=newActiveMQConnectionFactory("liuy","123456","tcp://192.168.91.8:61616"); Connectionconnection=connectionFactory.createConnection(); Sessionsession=connection.createSession(Boolean.TRUE,Session.AUTO_ACKNOWLEDGE); Destinationdestination=session.createTopic("my-topic"); MessageProducerproducer=session.createProducer(destination); producer.setDeliveryMode(DeliveryMode.PERSISTENT);//设置DeliveryMode.PERSISTENT模式 connection.start(); for(inti=0;i<3;i++){ TextMessagemessage=session.createTextMessage("message22--"+i); producer.send(message); } session.commit(); session.close(); connection.close(); } 1:要用持久化订阅,发送消息者要用DeliveryMode.PERSISTENT模式发现,在连接之前设定 2:一定要设置完成后,再start这个connection 3.3.2 消息的接收 publicvoidtest2()throwsException{ ConnectionFactorycf=newActiveMQConnectionFactory("liuy","123456","tcp://192.168.91.8:61616"); Connectionconnection=cf.createConnection(); connection.setClientID("cc1"); finalSessionsession=connection.createSession(Boolean.TRUE,Session.AUTO_ACKNOWLEDGE); Topictopic=session.createTopic("my-topic"); TopicSubscriberts=session.createDurableSubscriber(topic,"T1"); connection.start(); Messagemessage=ts.receive(); while(message!=null){ TextMessagetxtMsg=(TextMessage)message; System.out.println("收到消息:"+txtMsg.getText()); message=ts.receive(1000L); } session.commit(); session.close(); connection.close(); } 1:需要在连接上设置消费者id,用来识别消费者 2:需要创建TopicSubscriber来订阅 3:要设置好了过后再start 这个 connection 4:一定要先运行一次,等于向消息服务中间件注册这个消费者,然后再运行客户端发送信息,这个时候,无论消费者是否在线, 都会接收到,不在线的话,下次连接的时候,会把没有收过的消息都接收下来。

资源下载

更多资源
优质分享App

优质分享App

近一个月的开发和优化,本站点的第一个app全新上线。该app采用极致压缩,本体才4.36MB。系统里面做了大量数据访问、缓存优化。方便用户在手机上查看文章。后续会推出HarmonyOS的适配版本。

Nacos

Nacos

Nacos /nɑ:kəʊs/ 是 Dynamic Naming and Configuration Service 的首字母简称,一个易于构建 AI Agent 应用的动态服务发现、配置管理和AI智能体管理平台。Nacos 致力于帮助您发现、配置和管理微服务及AI智能体应用。Nacos 提供了一组简单易用的特性集,帮助您快速实现动态服务发现、服务配置、服务元数据、流量管理。Nacos 帮助您更敏捷和容易地构建、交付和管理微服务平台。

Rocky Linux

Rocky Linux

Rocky Linux(中文名:洛基)是由Gregory Kurtzer于2020年12月发起的企业级Linux发行版,作为CentOS稳定版停止维护后与RHEL(Red Hat Enterprise Linux)完全兼容的开源替代方案,由社区拥有并管理,支持x86_64、aarch64等架构。其通过重新编译RHEL源代码提供长期稳定性,采用模块化包装和SELinux安全架构,默认包含GNOME桌面环境及XFS文件系统,支持十年生命周期更新。

Sublime Text

Sublime Text

Sublime Text具有漂亮的用户界面和强大的功能,例如代码缩略图,Python的插件,代码段等。还可自定义键绑定,菜单和工具栏。Sublime Text 的主要功能包括:拼写检查,书签,完整的 Python API , Goto 功能,即时项目切换,多选择,多窗口等等。Sublime Text 是一个跨平台的编辑器,同时支持Windows、Linux、Mac OS X等操作系统。

用户登录
用户注册