Java消息服务基础

2016-02-19 16:01 2 1 收藏

岁数大了,QQ也不闪了,微信也不响了,电话也不来了,但是图老师依旧坚持为大家推荐最精彩的内容,下面为大家精心准备的Java消息服务基础,希望大家看完后能赶快学习起来。

【 tulaoshi.com - 编程语言 】


  在不同系统之间交换信息的一大障碍是如何在精确交换和格式化数据方面取得一致。Java Message Service( Java消息服务,简称JMS)通过提供一种与J2EE应用程序或传统系统交互的方法部分的解决了这个问题。
  
   !-- frame contents -- !-- /frame contents --   JMS的通用接口集合以异步方式发送或接收消息。异步方式接收消息显然是使用间断网络连接的客户机,诸如移动电话和PDA的最好的选择。另外, JMS采用一种宽松结合方式整合企业系统的方法,其主要的目的就是创建能够使用跨平台数据信息的、可移植的企业级应用程序,而把开发人力解放出来。
  
  Java消息服务支持两种消息模型:Point-to-Point消息(P2P)和发布订阅消息(Publish Subscribe messaging,简称Pub/Sub)。JMS规范并不要求供给商同时支持这两种消息模型,但开发者应该熟悉这两种消息模型的优势与缺点。
  
  P2P消息模型是在点对点之间传递消息时使用。假如应用程序开发者希望每一条消息都能够被处理,那么应该使用P2P消息模型。与Pub/Sub消息模型不同,P2P消息总是能够被传送到指定的位置。
  
  Pub/Sub模型在一到多的消息广播时使用。假如一定程度的消息传递的不可靠性可以被接受的话,那么应用程序开发者也可以使用Pub/Sub消息模型。换句话说,它适用于所有的消息消费程序并不要求能够收到所有的信息或者消息消费程序并不想接收到任何消息的情况。
  
  JMS通过答应创建持久订阅来简化时间相关性,即使消息预订者未激活也可以接收到消息。此外,使用持久订阅还可通过队列提供灵活性和可靠性,而仍然答应消息被发给许多的接收者。
  Topic Subscriber topic Subscriber =
  topicSession.createDurableSubscriber(topic, subscriptionName);

  Connection对象表示了到两种消息模型中的任一种的消息系统的连接。服务器端和客户机端对象要求治理创建的JMS连接的状态。连接是由Connection Factory创建的并且通过JNDI查寻定位。
  

//取得用于 P2P的 QueueConnectionFactory
  QueueConnectionFactory = queueConnectionFactory( );
  Context messaging = new InitialContext( );
  QueueConnectionFactory = (QueueConnectionFactory)
  Messaging.lookup(“QueueConnectionFactory”);
  
  //取得用于 pub/sub的 TopicConnectionFactory
  TopicConnectonFactory topicConnectionFactory;
  
  Context messaging = new InitialContext();
  topicConnectionFactory = (TopicConnectionFactory)
  messaging.lookup(“TopicConnectionFactory”);

  注重:用于P2P的代码和用于PublishSubscribe的代码非常相似。
  
  假如session被标记为transactional的话,确认消息就通过确认和校正来自动地处理。假如session没有标记为 transactional,你有三个用于消息确认的选项。
  
  · AUTO_ACKNOWLEDGE session将自动地确认收到一则消息。
  
  · CLIENT_ACKNOWLEDGE 客户端程序将确认收到一则消息,调用这则消息的确认方法。
  
  · DUPS_OK_ACKNOWLEDGE 这个选项命令session“懒散的”确认消息传递,可以想到,这将导致消息提供者传递的一些复制消息可能会出错。这种确认的方式只应当用于消息消费程序可以容忍潜在的副本消息存在的情况。
  

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)queueSession = queueConnection.createQueueSession(false, session.AUTO_ACKNOWLEDGE);//P2P
  
  topicSession = topicConnection.createTopicSession(false, session.AUTO_ACKNOWLEDGE); //Pub-Sub
  

  注重:在本例中,一个session目的从连结中创建,非值指出session是non-transactional的,并且 session将自动地确认收到一则消息。
  JMS现在有两种传递消息的方式。标记为NON_PERSISTENT的消息最多投递一次,而标记为PERSISTENT的消息将使用暂存后再转送的机理投递。假如一个JMS服务离线,那么持久性消息不会丢失但是得等到这个服务恢复联机时才会被传递。所以默认的消息传递方式是非持久性的。即使使用非持久性消息可能降低内务和需要的存储器,并且这种传递方式只有当你不需要接收所有的消息时才使用。
  
  虽然 JMS规范并不需要JMS供给商实现消息的优先级路线,但是它需要递送加快的消息优先于普通级别的消息。JMS定义了从0到9的优先级路线级别,0是最低的优先级而9则是最高的。更非凡的是0到4是正常优先级的变化幅度,而5到9是加快的优先级的变化幅度。举例来说:
  

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)topicPublisher.publish (message, DeliveryMode.PERSISTENT, 8, 10000); //Pub-Sub
  或
  queueSender.send(message, DeliveryMode.PERSISTENT, 8, 10000);//P2P

  

来源:http://www.tulaoshi.com/n/20160219/1610880.html

延伸阅读
       其实这个问题我原来翻译(破除Java神话之二:参数是传址的 )、转帖别人的具体解释(Java 应用程序中的按值传递语义 )和专门解释( 我对《Java 应用程序中的按值传递语义》的理解 )过,不过现在看来,原来翻译或者解释的角度是有问题的,从底层的角度解释并不直观,在交流的时候也轻易引起误...
   Java Applet 是用Java 语言编写的一些小应用程序,这些程序是直接嵌入到页面中,由支持Java的浏览器(IE 或 Nescape)解释执行能够产生特殊效果的程序。它可以大大提高Web页面的交互能力和动态执行能力。包含Applet的网页被称为Java-powered页,可以称其为Java支持的网页。 当用户访问这样的网页时,Applet被下载到用户的计算机上...
标签: Java JAVA基础
一、Java的发展史 1 什么是Java 美国硅谷有一句行话,每10年~15年有一次轮回。最近的一次轮回就是从Java开始。 Java是一个由Sun公司开发而成的新一代编程语言。使用它可在各式各样不同种机器、不同种操作平台的网络环境中开发软件。不论你使用的是哪一种WWW浏览器,哪一种计算机,哪一种操作系统,只要WWW...
控制语句——for练习 语句的嵌套应用 累加求和,计数器 循环嵌套 一、语句的嵌套应用 语句嵌套形式。其实就是语句中还有语句。形式多种多样,没有固定的格式和套路。 1、打印偶数 for(int x=1;x=10;x++) {  if(x%2==1) continue;  System.out.prinln(“x=”+x); } 二、累加求和,计数器 1、获取1~10的和,并打印。 思路://1,...
标签: Java JAVA基础
简言之,Java环境可用来开发能在任何计算平台上运行的应用软件。它实际上是一种非常基本且结构紧凑的技术,而它对WorldWide Web以及商业的总体影响已可同电子表格对PC机的影响相比拟。 Java是巨大的推动力量 Java已用动态的交互应用软件使Web栩栩如生。它使开发人员具有‘编写一次到处运行TM”的巨大能力。而且...

经验教程

73

收藏

5
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部