Java远程方法调用
主要参考
http://www.kaixinwenda.com/article-yxc135-7690958.html
http://bbs.chinaunix.net/thread-1179312-1-1.html
Java 远程处理
Java远程方法调用(RMI)提供了Java程序语言的远程通讯功能,这种特性使客户机上运行的程序可以调用远程服务器上的对象,使Java编程人员能够在网络环境中分布操作。
创建一个简单的Java分布式远程方法调用程序可以按以下几个步骤操作,
一、定义远程接口:
在 Java 中,远程对象是实现远程接口的类的实例, 远程接口声明每个要远程调用的方法。在需要创建一个远程对象的时候,我们通过传递一个接口来隐藏基层的实施细节,客户通过接口句柄发送消息即可。
远程接口具有如下特点:
1) 远程接口必须为public属性。如果不这样,除非客户端与远程接口在同一个包内,否则 当试图装入实现该远程接口的远程对象时,调用会得到错误结果。
2) 远程接口必须扩展接口java.rmi.Remote。
3) 除与应用程序本身特定的例外之外,远程接口中的每个方法都必须在自己的throws从句中 声明java.rmi.RemoteException。(或 RemoteException 的父类)。
4) 作为参数或返回值传递的一个远程对象(不管是直接,还是本地对象中嵌入)必须声明为远 程接口,而不应声明为实施类。
下面是远程接口的定义
package test;
import java.rmi.Remote;
import java.rmi.RemoteException;
import java.math.BigInteger;public interface Fib extends Remote {public int getFib(int n) throws RemoteException;
// public BigInteger getFib(BigInteger n) throws RemoteException;
}
二、实现远程接口:
远程对象实现类必须扩展远程对象java.rmi.UnicastRemoteObject类,并实现所定义的远程接口。远程对象的实现类中包含实现每个远程接口所指定的远程方法的代码。这个类也可以含有附加的方法,但客户只能使用远程接口中的方法。因为客户是指向接口的一个句柄,而不是它的哪个类。必须为远程对象定义构造函数,即使只准备定义一个默认构造函数,用它调用基础类构造函数。因为基础类构造函数可能会抛出 java.rmi.RemoteException,所以即使别无它用必须抛出java.rmi.RemoteException例外。
以下是远程对象实现类的声明:
package test;
import java.math.BigInteger;
import java.rmi.*;
import java.rmi.server.UnicastRemoteObject;public class FibImp extends UnicastRemoteObject implements Fib {public FibImp() throws RemoteException {super();}public int getFib(int n) throws RemoteException {return n+2;}}
三、编写服务器类:
包含 main 方法的类可以是实现类自身,也可以完全是另一个类。下面通过RmiSampleServer 来创建一个远程对象的实例,并通过java.rmi.registry.LocateRegistry类的createRegistry 方法从指定端口号启动注册服务程序,也可以通过执行 rmiregistry 命令启动注册服务程序,注册服务程序的缺省运行端口为 1099。必须将远程对象名字绑定到对远程对象的引用上: Naming.rebind("//localhost:8808/SAMPLE-SERVER" , Server);
以下是服务器类的声明:
package test;
import java.net.MalformedURLException;
import java.rmi.Naming;
import java.rmi.RemoteException;
import java.rmi.registry.LocateRegistry;
public class FibonacciServer {/*** @param args*/public static void main(String[] args) {try {LocateRegistry.createRegistry(8804); FibImp f = new FibImp();// 注册到 registry 中Naming.rebind("//localhost:8804/SAMPLE-SERVER", f);System.out.println("fib server ready");} catch (RemoteException re) {System.out.println("Exception in FibonacciImpl.main: " + re);} catch (MalformedURLException e) {System.out.println("MalformedURLException " + e);}}
}
四、编写使用远程服务的客户机类:
客户机类的主要功能有两个,一是通过Naming.lookup方法来构造注册服务程序 stub 程序实例,二是调用服务器远程对象上的远程方法。
以下是客户端类的声明:
package testClient;import test.Fib;
import java.math.BigInteger;
import java.net.MalformedURLException;
import java.rmi.Naming;
import java.rmi.NotBoundException;
import java.rmi.RemoteException;
public class FibClient {/*** @param args*/public static void main(String[] args) {String url = "//localhost:8804/SAMPLE-SERVER";try {Fib calc = (Fib) Naming.lookup(url);for (int i = 0; i < 10; ++i) {int f = calc.getFib(i);System.out.println(f);}} catch (MalformedURLException e) {e.printStackTrace();} catch (RemoteException e) {e.printStackTrace();} catch (NotBoundException e) {e.printStackTrace();}}
}
之前一直在eclipse下开发,对java的命令行编译,运行不是很清楚,下面的编译耗费了很多时间。
在包外面进行编译
javac test/*.java
javac testClient/*.java
使用rmic编译stub文件,在jdk1.5以后,利用java的reflect机制,因此就不会生成skeleton文件了
在windows下
运行rmic -classpath . test.FibImp,即可生成FibImp_Stub.class
在linux总是提示:/test/FibImp.class 中的类文件格式无效。 major.minor 版本 "51.0" 太新,此工具无法识别。
还需要排查
启动rmiregistry
直接输入rmiregistry即可
运行服务器:
java test.FibonacciServer
运行客户机:
java testClient.FibClient
下面是用实验室的Linux服务器的操作过程
一台服务器编译没有问题,但是在rmic生成存根class时,出现的问题很蹊跷,网上也搜不到:
error: ./test/FibImp.class 中的类文件格式无效。 major.minor 版本 "51.0" 太新,此工具无法识别。
error: 未找到类 test.FibImp。
这类错误出现的原因是: major.minor 就像是我们可以这么想像,同样是微软件的程序,32 位的应用程序不能拿到 16 位系统中执行那样。
参见 http://www.blogjava.net/Jay2009/archive/2009/04/23/267108.html
好吧,那就再换一台linux服务器
编译就有问题,应该是环境变量的问题,在javac 之后添加 -classpath . 即可
javac -classpath . testClient/FibClient.java
生成存根
rmic -classpath . test.FibImp
在运行程序的时候也要在java 后面添加-classpath .
Java远程方法调用相关推荐
- java中使用rmi进行远程方法调用
java中进行远程方法调用,能支持分布式计算.并且可以实现在server的修改,能反应到各个client. 假如server的ip是:192.168.11.2, server端的代码如下: /*** ...
- XML-RPC远程方法调用
一.简介 XML-RPC的全称是XML Remote Procedure Call,即XML远程方法调用. 它是一套允许运行在不同操作系统.不同环境的程序实现基于Internet过程调用的规范和一系列 ...
- Spring-整合JDBC-事务-远程方法调用RMI
一.spring整合JDBC spring整合jdbc使用了模版方法设计模式 定义一套规范,固定流程不变,传入可变内容 1.Maven项目添加依赖 spring-context坐标依赖 mysql驱动 ...
- “方法X对于类型Y是模糊的” Java模糊方法调用null错误
If you are reading this, chances are you got The method X is ambiguous for the type Y error when com ...
- 深入浅出JVM(五)之Java中方法调用
方法调用 要知道Java中方法调用唯一目的就是确定要调用哪一个方法 方法调用可以分为解析调用和分派调用,接下来会详细介绍 非虚方法与虚方法 非虚方法: 静态方法,私有方法,父类中的方法,被final修 ...
- Java知识整理——远程方法调用
什么是RMI ? Java远程方法调用(RMI)是一个Java API,它执行的面向对象的等价远程过程调用(RPC)的方法,包括了直接传输序列化的Java类和分布式垃圾收集的支持. 远程方法调用(RM ...
- 系统间通信2:通信管理与远程方法调用RMI
本文引用 : https://yinwj.blog.csdn.net/article/details/49120813 RMI : Remote Method Invocation,远程方法调用 RP ...
- RMI原理揭秘之远程方法调用
接上:http://guojuanjun.blog.51cto.com/277646/1423392 这一次我们从学习RegistryImpl_Stub.java和RegistryImpl_Skel. ...
- [Dnode]基于Node.js给浏览器提供异步远程方法调用
Dnode介绍 Dnode是一个提供异步双向远程方法调用的类库.网络socket和websocket风格的socket.io通信已经成为可能,所以系统的进程之间可以相互通信并且可以与运行在浏览器端的用 ...
最新文章
- EeePC1000hg安装archlinux20121201和openbox
- DPDK — 网卡初始化流程(Intel 82599 ixgbe 网卡驱动示例)
- memcache redis
- AD设备覆铜与同网络过孔的连接方式
- 计算机系统基础:磁盘调度知识笔记
- EF Core 小坑:DbContextPool 会引起数据库连接池连接耗尽
- P3959-宝藏【模拟退火】
- c语言上机指导答案清华,第一章自测练习答案清华大学c语言习题实验指导及课程设计...
- 中嵌套的页面如何操作父页面_UI设计中签到页面如何设计
- Linux基础四---系统监控硬盘分区
- LeetCode 要记得一些小trick
- Unity3D中英文对照手册
- 操作系统(OS)进程与调度
- 免费下载Microsoft Visual C++ 2010 Express (VSExpress)安装包地址分享速进
- 三个数相减的平方公式_小学二年级数学34个必考公式以及重难点解析
- 《Effective C++》第三版 第六章 继承与面向对象设计 32~35条例
- Ubuntu 键盘鼠标失效解决办法
- 【刷题日记】树的那些事儿(一)——基本操作
- ubuntu下载好了输入法怎么切换
- cityscapes场景图_图像语意分割训练Cityscapes数据集SegNet-ConvNet神经网络详解
热门文章
- can协议crc计算_CAN总线的升级版——CAN FD简介
- 五十四、Java日期Date,LocalDate类以及格式化输出
- NLP类别不均衡问题之loss大集合
- 深圳内推 | 腾讯AI Lab自然语言处理中心招聘NLP研究型实习生
- mybatis-plus逻辑删除数据后依然能够查出该数据
- 农行校招考试计算机类,农行校招:还有4个月,流程是这样!
- 国产计算机设备,小芯机:“天玥”中国第一台纯国产电脑诞生!
- 福步怎么自定义头像_苹果手机怎么截屏 苹果手机截屏方法有几种?原来还可以这么操作...
- java 8u111 8u112_JDK 8U112
- SpringMVC-设置编码过滤器