Java RMI详解

概要:
Java RMI 指的是远程方法调用 (Remote Method Invocation)。它是一种机制,能够让在某个 Java 虚拟机上的对象调用另一个 Java 虚拟机中的对象上的方法。可以用此方法调用的任何对象必须实现该远程接口。
Java RMI不是什么新技术(在Java1.1的时代都有了),但却是是非常重要的底层技术。
大名鼎鼎的EJB都是建立在rmi基础之上的,现在还有一些开源的远程调用组件,其底层技术也是rmi。
在大力鼓吹Web Service、SOA的时代,是不是每个应用都应该选用笨拙的Web Service组件来实现,通过对比测试后,RMI是最简单的,在一些小的应用中是最合适的。
下面通过一个简单的例子来说明RMI的原理和应用,下面这个例子是一个简单HelloWorld,但已涵盖RMI的核心应用与开发模式。
/**
* Created by IntelliJ IDEA.
* User: leizhimin
* Date: 2008-8-7 21:50:02
* 定义一个远程接口,必须继承Remote接口,其中需要远程调用的方法必须抛出RemoteException异常
*/
public interface IHello extends Remote {
/**
* 简单的返回“Hello World!"字样
* @return 返回“Hello World!"字样
* @throws java.rmi.RemoteException
*/
public String helloWorld() throws RemoteException;
/**
* 一个简单的业务方法,根据传入的人名返回相应的问候语
* @param someBodyName 人名
* @return 返回相应的问候语
* @throws java.rmi.RemoteException
*/
public String sayHelloToSomeBody(String someBodyName) throws RemoteException;
}
/**
* Created by IntelliJ IDEA.
* User: leizhimin
* Date: 2008-8-7 21:56:47
* 远程的接口的实现
*/
public class HelloImpl extends UnicastRemoteObject implements IHello {
/**
* 因为UnicastRemoteObject的构造方法抛出了RemoteException异常,因此这里默认的构造方法必须写,必须声明抛出RemoteException异常
*
* @throws RemoteException
*/
public HelloImpl() throws RemoteException {
}
/**
* 简单的返回“Hello World!"字样
*
* @return 返回“Hello World!"字样
* @throws java.rmi.RemoteException
*/
public String helloWorld() throws RemoteException {
return "Hello World!";
}
/**
* 一个简单的业务方法,根据传入的人名返回相应的问候语
*
* @param someBodyName 人名
* @return 返回相应的问候语
* @throws java.rmi.RemoteException
*/
public String sayHelloToSomeBody(String someBodyName) throws RemoteException {
return "你好," + someBodyName + "!";
}
}
/**
* Created by IntelliJ IDEA.
* User: leizhimin
* Date: 2008-8-7 22:03:35
* 创建RMI注册表,启动RMI服务,并将远程对象注册到RMI注册表中。
*/
public class HelloServer {
public static void main(String args[]) {
try {
//创建一个远程对象
IHello rhello = new HelloImpl();
//本地主机上的远程对象注册表Registry的实例,并指定端口为8888,这一步必不可少(Java默认端口是1099),必不可缺的一步,缺少注册表创建,则无法绑定对象到远程注册表上
LocateRegistry.createRegistry(8888);
//把远程对象注册到RMI注册服务器上,并命名为RHello
//绑定的URL标准格式为:rmi://host:port/name(其中协议名可以省略,下面两种写法都是正确的)
Naming.bind("rmi://localhost:8888/RHello",rhello);
// Naming.bind("//localhost:8888/RHello",rhello);
System.out.println(">>>>>INFO:远程IHello对象绑定成功!");
} catch (RemoteException e) {
System.out.println("创建远程对象发生异常!");
e.printStackTrace();
} catch (AlreadyBoundException e) {
System.out.println("发生重复绑定对象异常!");
e.printStackTrace();
} catch (MalformedURLException e) {
System.out.println("发生URL畸形异常!");
e.printStackTrace();
}
}
}
/**
* Created by IntelliJ IDEA.
* User: leizhimin
* Date: 2008-8-7 22:21:07
* 客户端测试,在客户端调用远程对象上的远程方法,并返回结果。
*/
public class HelloClient {
public static void main(String args[]){
try {
//在RMI服务注册表中查找名称为RHello的对象,并调用其上的方法
IHello rhello =(IHello) Naming.lookup("rmi://localhost:8888/RHello");
System.out.println(rhello.helloWorld());
System.out.println(rhello.sayHelloToSomeBody("熔岩"));
} catch (NotBoundException e) {
e.printStackTrace();
} catch (MalformedURLException e) {
e.printStackTrace();
} catch (RemoteException e) {
e.printStackTrace();
}
}
}
运行RMI服务端程序:
运行RMI客户端程序:
总结:
从上面的过程来看,RMI对服务器的IP地址和端口依赖很紧密,但是在开发的时候不知道将来的服务器IP和端口如何,但是客户端程序依赖这个IP和端口。
这也是RMI的局限性之一。这个问题有两种解决途径:一是通过DNS来解决,二是通过封装将IP暴露到程序代码之外。
RMI的局限性之二是RMI是Java语言的远程调用,两端的程序语言必须是Java实现,对于不同语言间的通讯可以考虑用Web Service或者公用对象请求代理体系(CORBA)来实现。
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
# Java
# RMI
# RMI简单实例代码
# RMI详细介绍
# java基于RMI远程过程调用详解
# Java RMI机制讲解
# 详解Java 中 RMI 的使用
# java RMI详细介绍及实例讲解
# Java rmi远程方法调用基本用法解析
# Java中的RMI使用方法详解
# 注册表
# 绑定
# 客户端
# 都是
# 问候语
# 抛出
# 来实现
# 机上
# 是一个
# 却是
# 一是
# 两种
# 可以用
# 这个问题
# 它是
# 希望能
# 并将
# 大名鼎鼎
# 非常重要
# 之二
相关文章:
建站主机选择指南:服务器配置与SEO优化实战技巧
,在苏州找工作,上哪个网站比较好?
如何在阿里云ECS服务器部署织梦CMS网站?
道歉网站制作流程,世纪佳缘致歉小吴事件,相亲网站身份信息伪造该如何稽查?
制作无缝贴图网站有哪些,3dmax无缝贴图怎么调?
武清网站制作公司,天津武清个人营业执照注销查询系统网站?
制作销售网站教学视频,销售网站有哪些?
php能控制zigbee模块吗_php通过串口与cc2530 zigbee通信【介绍】
制作网站怎么制作,*游戏网站怎么搭建?
如何在建站之星绑定自定义域名?
如何通过PHP快速构建高效问答网站功能?
广州网站建站公司选择指南:建站流程与SEO优化关键词解析
如何在万网主机上快速搭建网站?
网站制作企业,网站的banner和导航栏是指什么?
购物网站制作费用多少,开办网上购物网站,需要办理哪些手续?
网站制作专业公司有哪些,如何制作一个企业网站,建设网站的基本步骤有哪些?
利用JavaScript实现拖拽改变元素大小
整蛊网站制作软件,手机不停的收到各种网站的验证码短信,是手机病毒还是人为恶搞?有这种手机病毒吗?
赚钱网站制作软件,建一个网站怎样才能赚钱?是如何盈利的?
jQuery 常见小例汇总
建站VPS选购需注意哪些关键参数?
制作网站哪家好,cc、.co、.cm哪个域名更适合做网站?
实现点击下箭头变上箭头来回切换的两种方法【推荐】
c++怎么编写动态链接库dll_c++ __declspec(dllexport)导出与调用【方法】
头像制作网站在线观看,除了站酷,还有哪些比较好的设计网站?
网站企业制作流程,用什么语言做企业网站比较好?
怎么制作一个起泡网,水泡粪全漏粪育肥舍冬季氨气超过25ppm,可以有哪些措施降低舍内氨气水平?
,网站推广常用方法?
建站主机选购指南:核心配置优化与品牌推荐方案
网站制作服务平台,有什么网站可以发布本地服务信息?
如何选择高效可靠的多用户建站源码资源?
学校免费自助建站系统:智能生成+拖拽设计+多端适配
如何在建站之星网店版论坛获取技术支持?
盘锦网站制作公司,盘锦大洼有多少5G网站?
c# await 一个已经完成的Task会发生什么
如何快速搭建高效服务器建站系统?
广州网站制作的公司,现在专门做网站的公司有没有哪几家是比较好的,性价比高,模板也多的?
最好的网站制作公司,网购哪个网站口碑最好,推荐几个?谢谢?
建站之星如何保障用户数据免受黑客入侵?
定制建站哪家更专业可靠?推荐榜单揭晓
建站之星安装失败:服务器环境不兼容?
制作电商网页,电商供应链怎么做?
如何快速打造个性化非模板自助建站?
C++如何使用std::optional?(处理可选值)
如何在万网自助建站平台快速创建网站?
深圳网站制作案例,网页的相关名词有哪些?
建站之星安装模板失败:服务器环境不兼容?
长沙企业网站制作哪家好,长沙水业集团官方网站?
建站之星CMS建站配置指南:模板选择与SEO优化技巧
平台云上自助建站如何快速打造专业网站?
*请认真填写需求信息,我们会在24小时内与您取得联系。