Java RMI之HelloWorld篇

来源:互联网 发布:python单引号和双引号 编辑:程序博客网 时间:2024/05/22 05:02
Java RMI 指的是远程方法调用 (Remote Method Invocation)。它是一种机制,能够让在某个 Java 虚拟机上的对象调用另一个 Java 虚拟机中的对象上的方法。可以用此方法调用的任何对象必须实现该远程接口。
 
Java RMI不是什么新技术(在Java1.1的时代都有了),但却是是非常重要的底层技术。
大名鼎鼎的EJB都是建立在rmi基础之上的,现在还有一些开源的远程调用组件,其底层技术也是rmi。
 
在大力鼓吹Web Service、SOA的时代,是不是每个应用都应该选用笨拙的Web Service组件来实现,通过对比测试后,RMI是最简单的,在一些小的应用中是最合适的。
 
下面通过一个简单的例子来说明RMI的原理和应用,下面这个例子是一个简单HelloWorld,但已涵盖RMI的核心应用与开发模式。
/** * Created by IntelliJ IDEA. * User: leizhimin * Date: 2008-8-7 21:50:02 * 定义一个远程接口,必须继承Remote接口,其中需要远程调用的方法必须抛出RemoteException异常 */ public interface IHello extends Remote {     /**      * 简单的返回“Hello World!"字样      * @return 返回“Hello World!"字样      * @throws java.rmi.RemoteException      */     public String helloWorld() throws RemoteException;     /**      * 一个简单的业务方法,根据传入的人名返回相应的问候语      * @param someBodyName  人名      * @return 返回相应的问候语      * @throws java.rmi.RemoteException      */     public String sayHelloToSomeBody(String someBodyName) throws RemoteException; }

/** * Created by IntelliJ IDEA. * User: leizhimin * Date: 2008-8-7 21:56:47 * 远程的接口的实现 */ public class HelloImpl extends UnicastRemoteObject implements IHello {     /**      * 因为UnicastRemoteObject的构造方法抛出了RemoteException异常,因此这里默认的构造方法必须写,必须声明抛出RemoteException异常      *      * @throws RemoteException      */     public HelloImpl() throws RemoteException {     }     /**      * 简单的返回“Hello World!"字样      *      * @return 返回“Hello World!"字样      * @throws java.rmi.RemoteException      */     public String helloWorld() throws RemoteException {         return "Hello World!";     }     /**      * 一个简单的业务方法,根据传入的人名返回相应的问候语      *      * @param someBodyName 人名      * @return 返回相应的问候语      * @throws java.rmi.RemoteException      */     public String sayHelloToSomeBody(String someBodyName) throws RemoteException {         return "你好," + someBodyName + "!";     } }

/** * Created by IntelliJ IDEA. * User: leizhimin * Date: 2008-8-7 22:03:35 * 创建RMI注册表,启动RMI服务,并将远程对象注册到RMI注册表中。 */ public class HelloServer {     public static void main(String args[]) {         try {             //创建一个远程对象             IHello rhello = new HelloImpl();             //本地主机上的远程对象注册表Registry的实例,并指定端口为8888,这一步必不可少(Java默认端口是1099),必不可缺的一步,缺少注册表创建,则无法绑定对象到远程注册表上             LocateRegistry.createRegistry(8888);             //把远程对象注册到RMI注册服务器上,并命名为RHello             //绑定的URL标准格式为:rmi://host:port/name(其中协议名可以省略,下面两种写法都是正确的)             Naming.bind("rmi://localhost:8888/RHello",rhello); //            Naming.bind("//localhost:8888/RHello",rhello);             System.out.println(">>>>>INFO:远程IHello对象绑定成功!");         } catch (RemoteException e) {             System.out.println("创建远程对象发生异常!");             e.printStackTrace();         } catch (AlreadyBoundException e) {             System.out.println("发生重复绑定对象异常!");             e.printStackTrace();         } catch (MalformedURLException e) {             System.out.println("发生URL畸形异常!");             e.printStackTrace();         }     } }

/** * Created by IntelliJ IDEA. * User: leizhimin * Date: 2008-8-7 22:21:07 * 客户端测试,在客户端调用远程对象上的远程方法,并返回结果。 */ public class HelloClient {     public static void main(String args[]){         try {             //在RMI服务注册表中查找名称为RHello的对象,并调用其上的方法             IHello rhello =(IHello) Naming.lookup("rmi://localhost:8888/RHello");             System.out.println(rhello.helloWorld());             System.out.println(rhello.sayHelloToSomeBody("熔岩"));         } catch (NotBoundException e) {             e.printStackTrace();         } catch (MalformedURLException e) {             e.printStackTrace();         } catch (RemoteException e) {             e.printStackTrace();           }     } }
运行RMI服务端程序:

运行RMI客户端程序:

总结:
从上面的过程来看,RMI对服务器的IP地址和端口依赖很紧密,但是在开发的时候不知道将来的服务器IP和端口如何,但是客户端程序依赖这个IP和端口。
这也是RMI的局限性之一。这个问题有两种解决途径:一是通过DNS来解决,二是通过封装将IP暴露到程序代码之外。
RMI的局限性之二是RMI是Java语言的远程调用,两端的程序语言必须是Java实现,对于不同语言间的通讯可以考虑用Web Service或者公用对象请求代理体系(CORBA)来实现。
 
http://java.sun.com/javase/6/docs/technotes/guides/rmi/index.html
 
http://java.sun.com/javase/6/docs/technotes/guides
 
http://docs.huihoo.com/java/rmi/whitepage/index.html

0 0
原创粉丝点击
热门问题 老师的惩罚 人脸识别 我在镇武司摸鱼那些年 重生之率土为王 我在大康的咸鱼生活 盘龙之生命进化 天生仙种 凡人之先天五行 春回大明朝 姑娘不必设防,我是瞎子 破壁机打出的果汁很浓稠怎么办 榨的果汁不甜怎么办 11个月宝宝吃盐怎么办 1岁半宝宝长牙慢怎么办 小孩里面的牙黑怎么办 7个半月宝宝便秘怎么办 2个月婴幼儿便秘怎么办 3个月宝宝不消化怎么办 一天大便二三次不消化怎么办 不消化没胃口几天不大便怎么办? 两个月的宝宝拉绿屎怎么办 肠胃不好消化功能差怎么办 2岁宝宝消化不好怎么办 5天新生儿不拉大便怎么办 七个月宝宝一周不拉屎怎么办 七个月的宝宝消化不良怎么办 七个月宝宝消化不良拉肚子怎么办 宝宝六个月了便秘怎么办 宝宝拉水酸臭味怎么办 50天婴儿不拉屎怎么办 六个月宝宝吃米粉便秘怎么办 纯母乳喂养的宝宝便秘了怎么办 换奶粉拉绿色是怎么办 2个月宝宝发烧怎么办 小宝绿色稀大便怎么办 新生儿吃奶粉大便干燥怎么办 婴儿拉绿色奶瓣怎么办 宝宝吃奶粉大便干燥怎么办 婴儿吃奶粉不大便怎么办 孩子喝奶粉拉大便干怎么办 吃奶粉拉不出来怎么办 一岁半宝宝睡觉抱着睡放不下怎么办 3月大婴儿拉奶瓣怎么办 70多天宝宝便秘怎么办 宝宝喝奶粉上火便秘怎么办 a2奶粉吃了便秘怎么办 两个月宝宝两天没有大便怎么办 婴儿一直拉肚子吃药也不好怎么办 吃奶粉的婴儿便秘怎么办 一个多月小狗便便不成形怎么办 3个月宝宝不拉屎怎么办