• 什么是RMI?

维基百科:一种用于实现远程过程调用应用程序编程接口。它使客户机上运行的程序可以调用远程服务器上的对象。

  • 什么是序列化及反序列化

(1)序列化:把对象转换为字节序列的过程称为对象的序列化。

(2)反序列化:把字节序列恢复为对象的过程称为对象的反序列化。

对象序列化用途:

1) 把对象的字节序列永久地保存到硬盘上,通常存放在一个文件中;

    2) 在网络上传送对象的字节序列。

  • RMI远程调用步骤:

1),客户对象调用客户端辅助对象(stub对象)上的方法;

2),客户端辅助对象打包调用信息(变量,方法名),通过网络发送给服务端辅助对象(skeleton对象);

3),服务端辅助对象将客户端辅助对象发送来的信息解包,找出真正被调用的方法以及该方法所在对象;

4),调用真正服务对象上的真正方法,并将结果返回给服务端辅助对象;

5),服务端辅助对象将结果打包,网络发送给客户端辅助对象;

6),客户端辅助对象将返回值解包,返回给客户对象;

7),客户对象获得返回值;

  • RMI实例:

 共同部分,包含Person.java,ImyRemote.java;

import java.io.Serializable;
public class Person implements Serializable {
/**
* 序列化ID
*/
private static final long serialVersionUID = -3245478690496182643L;
public String name;
public int age;
public Person(String name, int age) {
this.name = name;
this.age = age;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}

  

import java.rmi.Remote;
import java.rmi.RemoteException;
public interface IMyRemote extends Remote {
String sayHello() throws RemoteException;
Person getPerson() throws RemoteException;
}

  Server部分,包含MyRemoteImpl.java,Server.java:

import java.rmi.RemoteException;
import java.rmi.server.UnicastRemoteObject; public class MyRemoteImpl extends UnicastRemoteObject implements IMyRemote {
public MyRemoteImpl() throws RemoteException {
}
@Override
public String sayHello() {
return "server say,hello world";
} @Override
public Person getPerson() throws RemoteException {
return new Person("张三",18);
}
}

  

import java.net.MalformedURLException;
import java.rmi.Naming;
import java.rmi.RemoteException; public class Server {
public static void main(String[] args) {
try{
// LocateRegistry.createRegistry(1099);
IMyRemote iRemote = new MyRemoteImpl();
Naming.rebind("rmi://198.181.47.219:1099/remoteServer", iRemote);
System.out.println("绑定成功");
}catch (RemoteException e){
System.out.println("RemoteException");
e.printStackTrace();
} catch (MalformedURLException e) {
System.out.println("MalformedURLException");
e.printStackTrace();
}
}
}

  Client部分,包含Client.Java:

import java.net.MalformedURLException;
import java.rmi.Naming;
import java.rmi.NotBoundException;
import java.rmi.RemoteException; public class Client {
public static void main(String[] args) throws RemoteException, NotBoundException, MalformedURLException {
IMyRemote client = (IMyRemote) Naming.lookup("rmi://198.181.47.219:1099/remoteServer");
System.out.println(client.sayHello());
Person p = client.getPerson();
System.out.println("name:" + p.getName() + "age:" + p.getAge());
}
}

  注:

(1) 启动远程服务前,需要先启动rmiregistry(Naming.rebind注册服务,rmiregistry必须运行);

(2)传输的对象的类型必须成为可序列化类型(编译器无法发现);

最新文章

  1. 【POJ2886】Who Gets the Most Candies?-线段树+反素数
  2. 【python游戏编程之旅】第七篇---pygame中的冲突检测技术
  3. pyqt5界面与逻辑分离--信号槽的装饰器实现方式
  4. 快速反射DataTable
  5. java定时器的使用
  6. Apriori算法例子
  7. svn 日志 offline 错误
  8. poj2752 Seek the Name, Seek the Fame
  9. C/C++ 指针的非空判断
  10. Internet History, Technology and Security (Week1)
  11. mtime,ctime,atime
  12. Vue自定义插件方法大全
  13. PAT 乙级 1080 MOOC期终成绩 (25 分)
  14. 2018.11.10 FCC java分享大会
  15. 第二篇:SpringBoot2.0整合ActiveMQ
  16. MVC 在action方法中获取当前action的控制器名和action名
  17. P1091 合唱队形 DP 最长升序列维护
  18. JSP入门实战下
  19. nginx的配置文件解析
  20. leetcode807

热门文章

  1. PAT L3-017. 森森快递
  2. 移动端适配,h5网页,手机端适配兼容方案.可以显示真实的1px边框和12px字体大小,dpr浅析
  3. 利用GPU训练网络时遇到的一些问题
  4. 【Redis】主从复制
  5. 【Offer】[35] 【复杂链表的复制】
  6. 洛谷 P1059【明明的随机数】 题解
  7. String对象为什么不可变
  8. Java开学测试
  9. 手写RPC框架指北另送贴心注释代码一套
  10. 服务器替换san存储