四年前也是 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 等一样的基于注册服务的东西就行了  .

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. 到时候要通知我哦,我也学习学习。

RMI使用学习 小结的更多相关文章

  1. Swift学习(六)-循环

    Swift风格的for小结Swift中使用in关键字标示循环的范围0..

  2. PHP学习之PHP变量

    PHP变量PHP3支持下面类型的变量:(一)、内部变量主要有整数,浮点数,字符串,数组,对象。在PHP中要在函数内部使用全局变量必须显式的说明。因此,语句:echo"$a${$a}";的显示结果完全等同于:echo"$a$hello";(三)PHP外部变量1、HTML表单当一个表单提交给PHP3script时,PHP会自动得到表单中的变量。任何用户端返回的cookies都将被自动转换为标准的PHP变量,就象GET和POST方法的数据。4、环境变量PHP自动将环境变量转换为普通的变量。

  3. JAVA/JSP学习系列之二(Tomcat安装)

    Tomcat是Apache组织的产品,sun公司对它的支持也相当不错。从这个地址可以下载:http://jakarta.apache.org/builds/tomcat/release/,我下载的是Tomcat32b4版本。注意,对于Tomcat其他设置,如果没有必要,是可以不改的,我这里讲的都是最简单而可行的方法,如果对你的改动没有把握,还是建议不要改动。

  4. JAVA/JSP学习系列之七

    ');}catch{thrownewJspException;}returnEVAL_PAGE;}这样将在jsp文件的自定义标签结束地方输出“HelloWorld!”然后,访问:http://localhost:[port]/tag/hello.jsp将出现:------------------------------------------------------------------HelloWorld!

  5. PHP的FTP学习(四)

    ">----------------------------------------------------------------------------------------------------------------------------------------------------------------

  6. PHP的FTP学习(一)[转自奥索]

    在这篇教程里,我将向你展示FTP怎样通过HTTP和FTP联接来传输文件,同时也会有一些简单的程序代码,跟我来吧!首先,你应该知道PHP是通过HTTP和FTP联接来传输文件的。通过HTTP上传文件早在PHP3中就已经出现,现在,新的FTP函数已经在新的PHP版本中出现了!使用PHP来FTP的步骤建立一个PHP的FTP联接必须遵守以下基本步骤:打开一个联接-发出认证信息-使用PHP函数操纵目录和传输文件。

  7. PHP学习正则表达式 课件第1/2页

    正则表达式:用于描述字符排列和匹配模式的一种语法规则。它主要用于字符串的模式分割、匹配、查找及替换操作。

  8. PHP学习 mysql第1/2页

    数据库的基本概念data 数据database 数据库DBMS 数据库管理系统DBS 数据库系统sql 是结构化查询语言

  9. java基于RMI远程过程调用详解

    这篇文章主要为大家详细介绍了java基于RMI远程过程调用,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  10. PHP的FTP学习(一)

    在这篇教程里,我将向你展示FTP怎样通过HTTP和FTP联接来传输文件,同时也会有一些简单的程序代码,跟我来吧!通过HTTP上传文件早在PHP3中就已经出现,现在,新的FTP函数已经在新的PHP版本中出现了!>--------------------------------------------------------------------------------检查输出结果,有一“AdditionalModules”区,这里列示了你的PHP支持的模块;如果你没发现FTP模块,你最好重新安装PHP,并

随机推荐

  1. 基于EJB技术的商务预订系统的开发

    用EJB结构开发的应用程序是可伸缩的、事务型的、多用户安全的。总的来说,EJB是一个组件事务监控的标准服务器端的组件模型。基于EJB技术的系统结构模型EJB结构是一个服务端组件结构,是一个层次性结构,其结构模型如图1所示。图2:商务预订系统的构架EntityBean是为了现实世界的对象建造的模型,这些对象通常是数据库的一些持久记录。

  2. Java利用POI实现导入导出Excel表格

    这篇文章主要为大家详细介绍了Java利用POI实现导入导出Excel表格,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  3. Mybatis分页插件PageHelper手写实现示例

    这篇文章主要为大家介绍了Mybatis分页插件PageHelper手写实现示例,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  4. (jsp/html)网页上嵌入播放器(常用播放器代码整理)

    网页上嵌入播放器,只要在HTML上添加以上代码就OK了,下面整理了一些常用的播放器代码,总有一款适合你,感兴趣的朋友可以参考下哈,希望对你有所帮助

  5. Java 阻塞队列BlockingQueue详解

    本文详细介绍了BlockingQueue家庭中的所有成员,包括他们各自的功能以及常见使用场景,通过实例代码介绍了Java 阻塞队列BlockingQueue的相关知识,需要的朋友可以参考下

  6. Java异常Exception详细讲解

    异常就是不正常,比如当我们身体出现了异常我们会根据身体情况选择喝开水、吃药、看病、等 异常处理方法。 java异常处理机制是我们java语言使用异常处理机制为程序提供了错误处理的能力,程序出现的错误,程序可以安全的退出,以保证程序正常的运行等

  7. Java Bean 作用域及它的几种类型介绍

    这篇文章主要介绍了Java Bean作用域及它的几种类型介绍,Spring框架作为一个管理Bean的IoC容器,那么Bean自然是Spring中的重要资源了,那Bean的作用域又是什么,接下来我们一起进入文章详细学习吧

  8. 面试突击之跨域问题的解决方案详解

    跨域问题本质是浏览器的一种保护机制,它的初衷是为了保证用户的安全,防止恶意网站窃取数据。那怎么解决这个问题呢?接下来我们一起来看

  9. Mybatis-Plus接口BaseMapper与Services使用详解

    这篇文章主要为大家介绍了Mybatis-Plus接口BaseMapper与Services使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  10. mybatis-plus雪花算法增强idworker的实现

    今天聊聊在mybatis-plus中引入分布式ID生成框架idworker,进一步增强实现生成分布式唯一ID,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

返回
顶部