为RMI实现类Jini的发现机制(1)

2016-02-19 18:56 6 1 收藏

每个人都希望每天都是开心的,不要因为一些琐事扰乱了心情还,闲暇的时间怎么打发,关注图老师可以让你学习更多的好东西,下面为大家推荐为RMI实现类Jini的发现机制(1),赶紧看过来吧!

【 tulaoshi.com - 编程语言 】

假如你从事过Jini开发,你会知道Jini客户端是不需要知道服务的位置的;它们简单地通过发现机制来获得一个代理以访问它们需要的服务。相反,在RMI(远程方法调用)中,你必须知道你想访问的服务器的URL。在本文中,我们将向你展示怎样为RMI实现一个类Jini的发现机制,这将使得一些客户端从必须知道RMI服务器URL的麻烦中解脱出来。

你可能首先会想,为什么要这么麻烦;为什么不干脆用Jini?我们也同意这样的逻辑,非凡是对新的系统来说。不管怎样,已经有许多基于RMI的系统存在,并且在Jini被Java开发的主流接受以前,我们仍然要提供更优雅的RMI解决方案。事实上,我们在这儿描述的工作,是这样的需求的结果:开发一项Jini服务使它同时可以作为一个独立的RMI服务器运行,但使用类Jini的发现机制。

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

本文主要是针对没有用过Jini的RMI开发者。通过深入观察Jini内部的运作,我们希望你能开始了解Jini的机制有多么强大。我们当然不是希望你重新实现Jini,但这篇文章能帮助你理解这些机制是怎样运作的。甚至可能帮助你说服你的经理或部门头头,该考虑将Jini作为一项可行的分布式系统技术。
  
  我们不会太深入Jini的发现机制,所以假如你对此不是很熟悉,我们建议你快速浏览一下Bill Venners的"Locate Services with the Jini Lookup Service."( http://www.javaworld.com/javaworld/jw-02-2000/jw-02-jiniology.Html)
  
  RMI基础和Jini查找
  
  在RMI中,客户端必须知道它所要连接的服务器的位置。RMI服务器的地址是URI的形式rmi://主机:端口/服务名,其中端口号是rmiregistry用来侦听请求的端口。例如:

Translator service
  
  =(Translator)Naming.lookup("rmi://theHost/SpanishTranslator");
  
  在Jini中,客户端通过一个Jini工具类来找到服务,比如ServiceDiscoveryManager。在下面的例子中,我们创建了一个ServiceTemplate的实例,该实例包含一个类列表;在我们的例子中,是我们要匹配的类??Translator.class:
  
  Class [] classes=new Class[]{Translator.class};
  
  ServiceTemplate tmpl=new ServiceTemplate(null,classes,null);
  
  ServiceDiscoveryManager lmgr=new ServiceDiscoveryManager(null,null);
  
  ServiceItem serviceItem =lmgr.lookup(tmpl,null);
  
  Translator service=serviceItem.service;

正如我们从例子中可以看到,ServiceDiscoveryManager用lookup()方法来查找任何与ServiceTemplate匹配的可用的服务。你还可以在服务查找中使用任何数字或属性;在这里我们出于保持简单和精练的考虑而没有这样做。
  
  比较两种查找机制,你会注重到在Jini版本中没有指定服务的位置。值得一提的是,假如必要,你也可以指定一个查找服务的位置,但不是你想要访问的实际服务的位置。Jini模型的强大之处是,我们不需要知道或关心服务位于何处。
  
  比较了RMI和Jini的发现机制之后,现在我们可以考虑怎样用类Jini的风格来访问一个RMI服务器。
  
  位置中立的RMI查找
  
  理想地,我们考虑查找Translator所发现的第一个匹配的实例。
  
  Translator service
  
  =(Translator)RMIDiscovery.lookup(clazz,id);
  
  在这里clazz是RMI服务的接口,id是区分实现clazz接口的不同服务器实例的唯一字符串标识。例如,要找到一个西班牙语翻译器,我们用下面的代码:
  
  Class clazz=Translator.class;
  
  String id="Spanish";
  
  现在我们对如何使用RMI发现机制有了一个更好的主意,我们来研究一下怎样实现它。在我们尝试实现我们“简陋的”RMI发现机制以前,先来看看Jini是怎样做的,再把这些原理/概念适用到RMI服务器和客户端上。
  
  发现机制
  
  Jini的基本发现机制联合使用多播UDP(用户数据报协议)(multicast UDP 见文后的Resources)和单播TCP/IP。简单来说,这意味着客户端发出一个多播的请求数据包,然后数据包被监听它的查找服务拾取。然后查找服务用单播连接连回客户端,并把查找服务的代理串行化成流通过此连接发送出去。此后客户端就可以和查找服务(的代理)交互以定位它需要的服务。

发现机制实际上比这要复杂得多,但我们只对其中多播UDP和单播TCP/IP的要害概念感爱好。我们并不打算实现一个等同的独立运行的RMI查找服务。相反我们将实现一个简单的多播监听器/单播分发器(multicast listener/unicast dispatcher)供RMI服务器使用,实际上我们使得每个RMI服务器作为它自己的查找服务。在客户端,我们为服务器端socket写个配对物??一个多播分发器/单播监听器(multicast dispatcher/unicast listener)。
  
  下面的表更具体地说明了RMI客户端和RMI服务器端间的交互。
  
  RMI客户端和RMI服务器端的交互
  
  服务器端客户端
  
  在多播地址上开始监听
  
  建立ServerSocket以监听来自服务器的单播响应。
  
  开始向多播地址发送UDP数据包
  
  解析收到的UDP数据包。假如有效,通
  
  过单播TCP/IP连回客户端。
  
  向客户端发送远程代理(remote stub)。
  
  从流中读取远程对象。
  
  关闭ServerSocket。停止发送UDP多播数据包
  
  开始使用服务。
  
  发现协议
  
  前面我们已经大致勾勒了客户端怎样发现服务器:它会指定一个接口类和一个唯一名字来确认一个服务器实例。这是因为多个实现相同接口的服务器可以同时运行。

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)


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

延伸阅读
标签: Web开发
四年前也是 Java  的 fans,也曾如火如荼的追求着 sun,追求着 java. 当然 RMI 肯定不会放过,但到目前为止还没有在任何一个项目中用过,昨天听了一个 java 老师的课,本来不去想听,可想想我交了这么多 money,最后还是去。最叫人恶心的是他讲的 RMI 一点实用价值都没...
标签: 服务器
Linux内核驱动fsync机制实现图解   在Linux内核中的IO模型基本分为4类: 1、同步阻塞I/O 2、同步非阻塞I/O 3、异步阻塞I/O 4、异步非阻塞I/O 同步:应用显式地通过函数访问数据,在此函数返回时就会得到结果(成功或失败)。 异步:应用会显示地通过函数提出访问或关注申请。数据到达时,硬件和驱动会通...
一.什么是窗口类   在Windows中运行的程序,大多数都有一个或几个可以看得见的窗口,而在这些窗口被创建起来之前,操作系统怎么知道该怎样创建该窗口,以及用户操作该窗口的各种消息交给谁处理呢?所以VC在调用Windows的API(CreateWindow或者CreateWindowEx)创建窗口之前,要求程序员必须定义一个窗口类(不是传统C++意义上的类)来规...
一般要求 首先,您必须有一个不带有参数的公用构造器。此构造器也应该通过调用各个特性的设置方法来设置特性的缺省值,例如: public Fireworks() { setAutoStart(true); setBackground(Color.black); setSpeed(10); setRadius(40); . . .} ...
小弟最近在编写一个O/RM组件(当然功能还是相当少的)。 大家都应该清楚把实体对象更新到数据库必须经过一系列的转换;特别是SQL语句的生成是比较费资源的,因为中间处里的东西实大是太多了。 在设计的过程中我就想如果一个对象插入数据库后把相应的Command保存在缓存中;下一次同一个类型的对象做这个操作时检测一下缓存如果有就直接拿来用这...

经验教程

170

收藏

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