- 浏览: 799932 次
- 性别:
- 来自: 哈尔滨
文章分类
最新评论
-
doloveme:
$sudo cp MONACO_Linux.ttf /usr/ ...
terminator 的配置 -
腾讯rep:
lowser
RSA加密算法c++简单实现 -
csuhanyong:
好YD啊,好YD
一图流:机械键盘各轴区别 -
doloveme:
1。其中:extman ,extmail下载http://ww ...
Ubuntu下安装postfix+extmail邮件服务器 -
doloveme:
repo sync出现“fatal: '../platform ...
Android 编译环境配置搭建(Ubuntu 12.04)及环境导致编译错误QA
JAVA RMI 快速入门实例
本实例为参考多篇文章写就而成,网上及书上各类文章介绍如何使用RMI有多种实例可参考,譬如有:
1. 用命令rmiregistry启动RMI注册服务的
2. 同时创建存根(stub)和骨架(skeleton)的
3. 只创建存根类的的(jdk1.2以后版本)
4. 通过RemoteRef和rmi://协议字串方式的
5. 比较少讲到的用LocateRegistry直接在代码上启动RMI注册服务的。
以上描述并非明显分类,比如,你总是可以选择用rmiregistry或者代码LocateRegistry启动RMI注册服务
下面我将介绍一个完整的实例,让初学者能快速体验RMI的功用。
分为以下四个步骤
1. 创建远程接口及声明远程方法(HelloInterface.java)
2. 实现远程接口及远程方法(继承UnicastRemoteObject)(Hello.java)
3. 启动RMI注册服务,并注册远程对象(HelloServer.java)
4. 客户端查找远程对象,并调用远程方法(HelloClient)
5. 执行程序:启动服务HelloServer;运行客户端HelloClient进行调用
具体代码及对应步骤如下:
1. 创建远程接口及声明远程方法(HelloInterface.java)
- package com.unmi;
- import java.rmi.*;
- /**
- * 远程接口必须扩展接口java.rmi.Remote
- */
- public interface HelloInterface extends Remote
- {
- /**
- * 远程接口方法必须抛出 java.rmi.RemoteException
- */
- public String say() throws RemoteException;
- }
2. 实现远程接口及远程方法(继承UnicastRemoteObject)Hello.java
- package com.unmi;
- import java.rmi.*;
- import java.rmi.server.*;
- /**
- * 扩展了UnicastRemoteObject类,并实现远程接口 HelloInterface
- */
- public class Hello extends UnicastRemoteObject implements HelloInterface
- {
- private String message;
- /**
- * 必须定义构造方法,即使是默认构造方法,也必须把它明确地写出来,因为它必须抛出出RemoteException异常
- */
- public Hello(String msg) throws RemoteException
- {
- message = msg;
- }
- /**
- * 远程接口方法的实现
- */
- public String say() throws RemoteException
- {
- System.out.println("Called by HelloClient");
- return message;
- }
- }
3. 启动RMI注册服务,并注册远程对象(HelloServer.java)
- package com.unmi;
- import java.rmi.Naming;
- import java.rmi.registry.LocateRegistry;
- public class HelloServer
- {
- /**
- * 启动 RMI 注册服务并进行对象注册
- */
- public static void main(String[] argv)
- {
- try
- {
- //启动RMI注册服务,指定端口为1099 (1099为默认端口)
- //也可以通过命令 $java_home/bin/rmiregistry 1099启动
- //这里用这种方式避免了再打开一个DOS窗口
- //而且用命令rmiregistry启动注册服务还必须事先用RMIC生成一个stub类为它所用
- LocateRegistry.createRegistry(1099);
- //创建远程对象的一个或多个实例,下面是hello对象
- //可以用不同名字注册不同的实例
- HelloInterface hello = new Hello("Hello, world!");
- //把hello注册到RMI注册服务器上,命名为Hello
- Naming.rebind("Hello", hello);
- //如果要把hello实例注册到另一台启动了RMI注册服务的机器上
- //Naming.rebind("//192.168.1.105:1099/Hello",hello);
- System.out.println("Hello Server is ready.");
- }
- catch (Exception e)
- {
- System.out.println("Hello Server failed: " + e);
- }
- }
- }
4. 客户端查找远程对象,并调用远程方法(HelloClient)
- package com.unmi;
- import java.rmi.Naming;
- public class HelloClient
- {
- /**
- * 查找远程对象并调用远程方法
- */
- public static void main(String[] argv)
- {
- try
- {
- HelloInterface hello = (HelloInterface) Naming.lookup("Hello");
- //如果要从另一台启动了RMI注册服务的机器上查找hello实例
- //HelloInterface hello = (HelloInterface)Naming.lookup("//192.168.1.105:1099/Hello");
- //调用远程方法
- System.out.println(hello.say());
- }
- catch (Exception e)
- {
- System.out.println("HelloClient exception: " + e);
- }
- }
- }
5. 执行程序:启动服务HelloServer;运行客户端HelloClient进行调用
代码如何编译这里就不细讲
(1)打开一个Dos窗口执行命令 java com.unmi.HelloServer 启动服务HelloServer
E:workspaceTestRMIbin>java com.unmi.HelloServer
Hello Server is ready.
运行成功则可以看到 Hello Server is ready
(2)打开另一个Dos窗口执行命令 java com.unmi.HelloClient 运行客户端程序
E:workspaceTestRMIbin>java com.unmi.HelloClient
Hello, world!
调用成功则可以看到 Hello, world!
并且在启动服务端的窗口中看到紧跟 Hello Server is ready. 打印出
Called by HelloClient
如果您能一路顺畅的执行到这里,恭喜!您已度过了一个轻快的RMI之旅。
最后来个说明:
本实例中并没有用到JDK所带的命令 rmic 编译实现类得到存根(Stub)类,也没用命令 rmiregistry 命令来启动RMI注册服务。在启动 rmiregistry之前必须能让它加载到相应的stub类,这就是造成**_Stub 类找不到的原因。
如果只是按上面的代码,则服务程序 HelloServer 和客户端程序 HelloClient 都必须运行在本机(如此则RMI有何意义呢?);别急,只要修改HelloClient类,使用第二种形式的lookup查找语句,注释第一条 lookup语句,取消注释第二条lookup语句
//HelloInterface hello = (HelloInterface) Naming.lookup("Hello");
//如果要从另一台启动了RMI注册服务的机器上查找hello实例
HelloInterface hello = (HelloInterface)Naming.lookup("//192.168.1.105:1099/Hello");
其中的IP地址和端口号1099为 RMI 注册服务器的IP和端口号,这样你的HelloClient就可以在另一台机器运行了,当然HelloInterface类必须能找到(但也可指定参数- Djava.rmi.server.codebase从网络加载HelloInterface类)。lookup("Hello")默认为从本机 127.0.0.1的1099端口上查找Hello命令对象,如果第二条语句写成lookup("192.168.1.105/Hello")与原语句是同等的,因为默认端口号就是1099。
代码中 HelloServer 和 HelloClient 省略了设置安全管理器的过程 System.setSecurityManager(new RMISecurityManager()); ,如果设置的安全管理则必须编写相应的访问策略文件,并且在执行时指定参数
无论是启动服务端还是客户端都可以用参数 -Djava.rmi.server.codebase=http://unmi.blogcn.cn/bin 的形式,像JNP一样从网络上加载类,这样更方便于RMI客户端的部署,如RMI客户端是一个Applet
可以拿单独一台机器运行 rmiregistry (它需要能加载到相应的stub类,设置classpath)或用LocateRegistry.createRegistry(port),只作为 RMI远程对象的RMI集中注册的服务器,真正提供服务对象只往上注册,客户端只需从注册服务器上查找远程对象引用,然后调用远程方法,具体由谁提供服务由注册服务器来帮助联络。
还可以用 RMI Activation 编程方式来实现RMI远程方法调用,具体请参考 http://java.sun.com/j2se/1.4.2/docs/guide/rmi/activation.html
把HelloServer和HelloClient中的 "//192.168.1.105:1099/Hello 写成 rmi:/192.168.1.105:1099/Hello 感觉会好看一些,因为直接感觉就是在处理rmi协议。
参考资料:
1. JAVA RMI Tutorial
2. Getting Started Using RMI
3. JavaRMI入门实战
4. 使用RMI和CORBA进行分布式java程序设计
5. Think in java中网络编程RMI部分
发表评论
-
linux生成指定大小的文件
2015-08-26 16:02 1653# dd if=/dev/zero of=50M.file ... -
SpringMVC入门
2015-07-02 18:23 736目录 介绍 实例 总结 参考资料 介绍 Sp ... -
java线程中yield(),sleep(),wait()区别详解
2014-09-03 13:23 6251、sleep() 使当前线程(即调用该方法的线程)暂停执 ... -
线程方法 joine
2014-09-02 11:51 679Example1: Java代码 ... -
恢复 git reset -hard 的误操作
2014-08-30 15:10 854有时候使用Git工作得小心翼翼,特别是涉及到一些高级操作,例如 ... -
安装下载jamesAMES邮件服务器
2014-08-22 14:24 774UBUNTU下的JAMES邮件服务器 下载文件james- ... -
ubuntu james 2.3 部署
2014-08-22 14:23 791参考文章 1、需要用到很多权限和1024下的端口,用roo ... -
E: Sub-process /usr/bin/dpkg returned an error code (1)
2014-08-21 10:40 827Sub-process /usr/bin/dpkg retu ... -
Java transient关键字
2014-06-24 15:46 463Volatile修饰的成员变量在每次被线程访问时,都强迫从主内 ... -
Ubuntu系统如何设置vpn
2014-06-20 09:28 221因为一些原因,我们可能需要使用vpn,很 ... -
部署Exchange2007
2014-06-06 10:02 522Exchange邮件服务器是一个不错的通信消息平台, ... -
ubuntu 挂载(感觉挂载iso相当舒服)
2014-06-03 17:20 916当然首先在/media目录下先新建个文件夹当挂载点先以挂载 ... -
InputStream、OutputStream、String的相互转换
2014-06-03 17:19 5431、字符串转inputStream Java ... -
Windows XP格式化U盘为NTFS的方法
2014-06-03 10:41 739大于4G的U盘,最好将其格式化为NTFS格式,因为FAT3 ... -
google hosts
2014-05-31 11:29 250127.0.0.1localhost 127.0.1.1h ... -
google hosts
2014-05-30 18:03 4#Google Services START203.208.4 ... -
terminator 的配置
2014-05-15 09:15 1372让termintor 文字背景和ubuntu 一样 ... -
Ubuntu下安装postfix+extmail邮件服务器
2014-05-10 12:19 1771系统:ubuntu-10.04.3-server-amd64 ... -
Discuz X2.5 取消登陆密码错误15分钟限制的方法
2014-05-09 15:15 1246个人不推荐取消登录密码错误15分钟后再试的限制,就现在有限制 ... -
Ubuntu下搭建FTP服务器
2014-05-08 19:24 782后台一直提示wordperss版本和插件有更新,看着碍眼,决 ...
相关推荐
Java RMI实例
JAVARMI实例[文].pdf
java rmi java rmijava rmi javajava rmi java rmi rmi
java rmi小例子源代码 ,运行Reg.java ,再执行Client客户端代码就能看效果。如果在不同jvm下执行,注意接口定义包路径客服端和服务端必须保持一致。 客服端包含文件有服务端接口的定义文件。
创建客户端RMI调用服务端的应用程序。 启动服务端,再启动客户端,测试是否调用成功。 如果客户端和服务端不在同一台电脑上,则需要对刚才定义的服务类采用rmic 编译一个客户端的框架类_stub并拷贝到客户端的类...
java rmi spring 使用实例,内涵服务端和客户端的源代码,测试可用。
JAVA分布式之RMI实例教程网络通信原理[收集].pdf
java RMI技术实现的网络聊天室 编译通过,很完整的。代码很有参考价值
采用JAVA rmi,带图形界面,完全由自己实现的聊天室,具备基本的聊天功能,可以自己扩充功能
java rmi 完整的简单例子 包含详细的文档说明
检测javaRMI反序列化漏洞
Java编程rmi实例,给出远程方法调用技术在java方面的具体例子。
java RMI
这是一个java远程调用的例子,可运行。
java RMI实现代码。分为客户端和服务器端,有清楚的代码注释。
rmi的详细例子,rmi的详细用法,一看就懂
Java RMI 简单示例
JavaRMI.pdf
JAVA_RMI_实例.pdf