[转]Java远程方法调用

时间:2022-09-05 12:41:03

Java远程方法调用,即Java RMI(Java Remote Method Invocation)是Java编程语言里,一种用于实现远程过程调用应用程序编程接口。它使客户机上运行的程序可以调用远程服务器上的对象。远程方法调用特性使Java编程人员能够在网络环境中分布操作。RMI全部的宗旨就是尽可能简化远程接口对象的使用。

Java RMI极大地依赖于接口。在需要创建一个远程对象的时候,程序员通过传递一个接口来隐藏底层的实现细节。客户端得到的远程对象句柄正好与本地的根代码连接,由后者负责透过网络通信。这样一来,程序员只需关心如何通过自己的接口句柄发送消息。

接口的两种常见实现方式是:最初使用JRMP(Java Remote Message Protocol,Java远程消息交换协议)实现;此外还可以用与CORBA兼容的方法实现。RMI一般指的是编程接口,也有时候同时包括JRMP和API(应用程序编程接口),而RMI-IIOP则一般指RMI接口接管绝大部分的功能,以支持CORBA的实现。

最初的RMI API设计为通用地支持不同形式的接口实现。后来,CORBA增加了传值(pass by value)功能,以实现RMI接口。然而RMI-IIOPJRMP实现的接口并不完全一致。

所使用Java包的名字是java.rmi

你也可以参考一篇博文 http://6221123.blog.51cto.com/6211123/1112619 它会一步一步教你如何搭建一个真正RMI分布式程序

四年前也是 Java  的 fans,也曾如火如荼的追求着 sun,追求着 java. 当然 RMI 肯定不会放过,但到目前为止还没有在任何一个项目中用过,昨天听了一个 java 老师的课,本来不去想听,可想想我交了这么多 money,最后还是去。最叫人恶心的是他讲的 RMI 一点实用价值都没有,而且有的理论也不对。真的误导人啊,学术理论和实践是不能够分离的,老师是这样的,只能靠学生自己动手丰衣足食了。昨天晚上用了一点时间,从新研究了一下 RMI。举个例子作为 RMI 学习的终结吧。
        在写这篇文章前也访问了中国电信的高级工程师,根据他的介绍,RMI 有很多实现方式,而且现在他发现 RMI 在大规模分布式系统中,效率和性能不是很好。目前他带领的团队正在自行开发分布式应用。
        随着 web 2.0 时代的到来,SOA 开发思想的普及应用。分布式应用,将又一次走向高潮。
        RMI  开发步骤大家都很清楚,这里举个不用手动启动 rmiRegistry, 也不要指定 codebase 和web server 的例子.底层 TCP/IP 细节我们不用去管他,你就把他看成像 SOAP、JNDI 等一样的基于注册服务的东西就行了 [转]Java远程方法调用 .

1. 远程接口
import java.rmi.Remote;
import java.rmi.RemoteException;

public interface IRMI extends Remote {
 public Object invoke(ITask task) throws RemoteException;
}
2.远程接口实现

/**
 * @author Jack.Wang
 * 
 */
import java.rmi.RemoteException;
import java.rmi.server.UnicastRemoteObject;

public class IRMIImpl extends UnicastRemoteObject implements IRMI {

protected IRMIImpl() throws RemoteException {
  super();
 }

public Object invoke(ITask task) throws RemoteException {
  System.out.println("注意:这是一个远程调用");
  Object obj = task.doWork();
  System.out.println("调用ITask.doWork()方法的返回值:" + obj.toString());
  // 客户端调用,可以在服务器端播放需要的音乐
  ProcessCaller.callMp3();
  return obj;
 }
}
3.  任务接口
/**
 * @author Jack.Wang
 * 
 */
import java.io.Serializable;
public interface ITask extends Serializable {
 public Object doWork();
}
4.  任务实现类
/**
 * @author Jack.Wang
 * 
 */
public class TaskImpl implements ITask {

public Object doWork() {
  System.out.println("当前程序处于远程调用中");
  return Thread.currentThread().getName() + " "
    + new Date(System.currentTimeMillis());
 }
}
5.在java中调用windows程序
public class ProcessCaller {
 
 public static void callMp3() {
  Runtime ru = Runtime.getRuntime();
  try {
   // 调用播放器文件播放指定MP3
   Process p1 = ru
     .exec("C:\\Program Files\\Windows Media Player\\wmplayer D:\\Jack\\Mp3\\5.秋天不回来-王强.mp3");
  } catch (Exception e) {

}
 }
}
6. Server 端代码 
/**
 * @author Jack.Wang
 * 
 */
import java.rmi.Naming;
import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry;

public class RMIServer {

public static void registRemoteObject() throws Exception {
  IRMIImpl impl = new IRMIImpl();
  Naming.rebind("rmi://210.43.109.25:1111/mytask", impl);
  System.out.println("bound success!");
 }

private static Registry createRegistry() {
  Registry registry = null;
  int port = 1111;
  try {
   registry = LocateRegistry.getRegistry("210.43.109.25", port);
   registry.list();
   System.out.println("Register the exist server!");
  } catch (final Exception e) {
   try {
    registry = LocateRegistry.createRegistry(port);
    System.out.println("Register the exist server!port=" + port);
   } catch (final Exception ee) {
    ee.printStackTrace();
   }
  }
  return registry;
 }

/**
  * 将对象注册到rmi服务器上
  */
 public static void bind() {
  Registry registry = null;
  registry = createRegistry();
  try {
   IRMIImpl impl = new IRMIImpl();
   registry.rebind("mytask", impl);
   System.out.println("mytask server start!");
  } catch (Exception e) {
   e.printStackTrace();
  }
 }

/**
  * @param args
  */
 public static void main(String[] args) {
  try {
   bind();
  } catch (Exception e) {
   e.printStackTrace();
  }
 }

}
7. Client 端代码

/**
 * @author Jack.Wang
 * 
 */ 
public class RMIClient {
 public static void getRemoteObject() throws Exception {
  IRMI obj = (IRMI) Naming.lookup("rmi://210.43.109.28:1111/mytask"); // 得到远程发布的服务
  TaskImpl task = new TaskImpl();
  Object result = obj.invoke(task); // 调用远程服务的方法
  System.out.println(result.toString());
 }

public static void main(String[] args) {
  try {
   getRemoteObject();
  } catch (Exception e) {
   e.printStackTrace();
  }
 }
}

小结:
        建议把以上程序打包成 jar 文件,你可以在不同机子间测试。
        RMI 就这么简单,如果你觉得他不爽,就自己封装 socket. 到时候要通知我哦,我也学习学习。

[转]Java远程方法调用的更多相关文章

  1. SpringBoot里使用RMI进行远程方法调用

    一.Java RMI定义 Java RMI:Java远程方法调用,即Java RMI(Java Remote Method Invocation)是Java编程语言里,一种用于实现远程过程调用的应用程 ...

  2. 简单实现Java的RMI——远程方法调用

    一.RMI简介: 说到RMI就不得不说RPC了. RPC:(Remote Procedure Call),远程过程调用. RMI(Remote Method Invocation),远程方法调用. R ...

  3. 【Java Web开发学习】远程方法调用RMI

    Java RMI 远程方法调用Remote Method Invocation 转载:http://www.cnblogs.com/yangchongxing/p/9078061.html 1.创建远 ...

  4. Java APi 之 RMI远程方法调用

    一.什么是RPC RPC全称是remote procedure call,即远程过程调用.它是一种协议,用于从远程计算机上请求服务. 例如有两台服务器A和B,A上的应用想要调用B上应用的方法,但是他们 ...

  5. XML-RPC远程方法调用

    一.简介 XML-RPC的全称是XML Remote Procedure Call,即XML远程方法调用. 它是一套允许运行在不同操作系统.不同环境的程序实现基于Internet过程调用的规范和一系列 ...

  6. Java远程方法协议(JRMP)

    Java远程方法协议(英语:Java Remote Method Protocol,JRMP)是特定于Java技术的.用于查找和引用远程对象的协议.这是运行在Java远程方法调用(RMI)之下.TCP ...

  7. RMI远程方法调用

    RMI远程方法调用:适用于 客户端 调用 服务器 内的方法:(Kotlin 语言编写) 如果业务为二个服务器之间的通信,还是得用消息队列的形式,因为RMI 不适合 双向 调用 下面介绍RMI 的使用方 ...

  8. Java RMI 远程方法调用

    Java RMI 指的是远程方法调用 (Remote Method Invocation).它是一种机制,能够让在某个 Java 虚拟机上的对象调用另一个 Java 虚拟机中的对象上的方法.可以用此方 ...

  9. Java RMI远程方法调用

    RMI(远程接口调用) 1. RMI的原理: RMI系统结构,在客户端和服务器端都有几层结构. 方法调用从客户对象经占位程序(Stub).远程引用层(Remote Reference Layer)和传 ...

随机推荐

  1. Bootstrap~表单Form

    回到目录 在进行自己的后台改版时,大体布局都使用了bootstrap,剩下的表单部分没理由不去使用它,对于表单的美化和布局,bootstrap做的也是很不错的,有大气的边框,多功能的按钮及宏观的表单布 ...

  2. iOS中UIWebView与其中网页的javascript的交互

    首发:个人博客,更新&纠错&回复 1.本地语言调js的方式与android中的方式类似,也是向WebView控件发送要调用的js语句 2. 但js调本地语言,则不是像android那样 ...

  3. Fresco图片框架内部实现原理探索

    流行的网络框架 目前流行的网络图片框架: Picasso.Universal Image Loader.Volley的(ImageLoader.NetworkImageView).Glide和Fres ...

  4. 140 - The 12th Zhejiang Provincial Collegiate Programming Contest(第三部分)

    Earthstone Keeper Time Limit: 4 Seconds      Memory Limit: 65536 KB Earthstone Keeper is a famous ro ...

  5. 【CF553E】Kyoya and Train 最短路+cdq分治+FFT

    [CF553E]Kyoya and Train 题意:有一张$n$个点到$m$条边的有向图,经过第i条边要花$c_i$元钱,经过第i条边有$p_{i,k}$的概率要耗时k分钟.你想从1走到n,但是如果 ...

  6. Linux安装go

    在 http://golang.org/dl/下载最新的linux版本,并把它提取到/usr/local目录,在此目录下进行解压缩 $ sudo tar -xzf go1.9.1.linux-amd6 ...

  7. minicom支持向串口自动发送命令的功能

    1. 用法 minicom -S <script name> -C <log name> 参数解析: -S: 指定要执行的脚本 -C: 指定输出日志文件名 2. 既然可以指定脚 ...

  8. 总结sql用法及基础语法 第一章 三范式

    第一范式(1NF)设置了一个有组织的数据库非常基本的规则: 定义所需要的数据项,因为它们成为在表中的列.放在一个表中的相关的数据项. 确保有数据没有重复的组. 确保有一个主键. PRIMARY KEY ...

  9. Visual Studio2010 支持MVC4开发

    最近的项目有一个维护的版本使用的是Visual Studio2010+MVC4开发的,记录一下软件的开发环境 ============================================= ...

  10. WIN10局域网共享&comma;经常出现无法访问的现象的解决方法

    WIN10的局域网共享是真操蛋啊,用着好好的,重启了一下,突然就不好用了,其他人无法访问我的电脑,百度了半天也没有找到能解决的访问,文章中说的都试过了,该开启的也都开启了,防火墙也关了,没用,后来想着 ...