- 浏览: 545396 次
- 性别:
- 来自: 广州
-
文章分类
- 全部博客 (339)
- JavaBase (27)
- J2EE (70)
- Database (22)
- Spring (3)
- struts1.x (6)
- struts2.x (16)
- Hibernate (10)
- IBatis (4)
- DWR (1)
- SSH (5)
- Oracle (31)
- HTML (12)
- javascript (11)
- Thinking (3)
- Workflow (5)
- Live (13)
- Linux (23)
- ExtJS (35)
- flex (10)
- php (3)
- Ant (10)
- ps (1)
- work (2)
- Test (1)
- Regular Expressions (2)
- HTTPServer (2)
- 方言 (1)
- 生活 (2)
- Sybase PowerDesigner (0)
最新评论
-
mikey_5:
非常感谢楼主的分享,<parameter propert ...
Check the output parameters (register output parameters failed) IN Ibatis -
影子_890314:
我现在也有这个错误,求解!
Check the output parameters (register output parameters failed) IN Ibatis -
358135071:
学习了,感谢分享!
使用hibernate 代替 mysql 中 limit 進行分頁 -
wjpiao:
你下面的“正确的映射”里面不是还是有number类型吗?
Check the output parameters (register output parameters failed) IN Ibatis -
zh_s_z:
很有用!弄一份吧!
Oracle数据库分区表操作方法
RMI,远程方法调用(Remote Method Invocation)是Enterprise Java
Beans的支柱,是建立分布式Java
应用程序的方便途径。RMI是非常容易使用的,但是它非常的强大。
RMI的基础是接口,RMI构架基于一个重要的原理:定义接口和定义接口的具体实现是分开的。下面我们通过具体的例子,建立一个简单的远程计算服务和使用它的客户程序
一个正常工作的RMI系统由下面几个部分组成:
下面我们一步一步建立一个简单的RMI系统。首先在你的机器里建立一个新的文件夹,以便放置我们创建的文件,为了简单起见,我们只使用一个文件夹存放客户端和服务端代码,并且在同一个目录下运行服务端和客户端。
如果所有的RMI文件都已经设计好了,那么你需要下面的几个步骤去生成你的系统:
1、 编写并且编译接口的Java代码
2、 编写并且编译接口实现的Java代码
3、 从接口实现类中生成 Stub 和 Skeleton 类文件
4、 编写远程服务的主运行程序
5、 编写RMI的客户端程序
6、 安装并且运行RMI系统
1、接口
第一步就是建立和编译服务接口的Java代码。这个接口定义了所有的提供远程服务的功能,下面是源程序:
- //Calculator.java
- //define the interface
- import java.rmi.Remote ;
- public interface Calculator extends Remote
- {
- public long add(long a, long b)
- throws java.rmi.RemoteException ;
- public long sub(long a, long b)
- throws java.rmi.RemoteException ;
- public long mul(long a, long b)
- throws java.rmi.RemoteException ;
- public long div(long a, long b)
- throws java.rmi.RemoteException ;
- }
注意,这个接口继承自Remote,每一个定义的方法都必须抛出一个RemoteException异常对象。
建立这个文件,把它存放在刚才的目录下,并且编译。
>javac Calculator.java
2、接口的具体实现
下一步,我们就要写远程服务的具体实现,这是一个CalculatorImpl类文件:
- //CalculatorImpl.java
- //Implementation
- import java.rmi.server.UnicastRemoteObject ;
- public class CalculatorImpl extends UnicastRemoteObject implements Calculator
- {
- // 这个实现必须有一个显式的构造函数,并且要抛出一个RemoteException异常
- public CalculatorImpl()
- throws java.rmi.RemoteException {
- super ();
- }
- public long add(long a, long b)
- throws java.rmi.RemoteException {
- return a + b;
- }
- public long sub(long a, long b)
- throws java.rmi.RemoteException {
- return a - b;
- }
- public long mul(long a, long b)
- throws java.rmi.RemoteException {
- return a * b;
- }
- public long div(long a, long b)
- throws java.rmi.RemoteException {
- return a / b;
- }
- }
同样的,把这个文件保存在你的目录里然后编译他。
这个实现类使用了UnicastRemoteObject去联接RMI 系统。在我们的例子中,我们是直接的从UnicastRemoteObject这个类上继承的,事实上并不一定要这样做,如果一个类不是从 UnicastRmeoteObject上继承,那必须使用它的exportObject()方法去联接到RMI。
如果一个类继承自 UnicastRemoteObject,那么它必须提供一个构造函数并且声明抛出一个RemoteException对象。当这个构造函数调用了 super(),它久激活UnicastRemoteObject中的代码完成RMI的连接和远程对象的初始化。
3、Stubs 和Skeletons
下一步就是要使用RMI编译器rmic来生成桩和框架文件,这个编译运行在远程服务实现类文件上。
>rmic CalculatorImpl
在你的目录下运行上面的命令,成功执行完上面的命令你可以发现一个Calculator_stub.class文件,如果你是使用的Java2SDK,那么你还可以发现Calculator_Skel.class文件。
4、主机服务器
远程RMI服务必须是在一个服务器中运行的。CalculatorServer类是一个非常简单的服务器。
- //CalculatorServer.java
- import java.rmi.Naming ;
- public class CalculatorServer {
- public CalculatorServer() {
- try {
- Calculator c = new CalculatorImpl();
- Naming .rebind("rmi://localhost:1099/CalculatorService" , c);
- } catch (Exception e) {
- System .out.println("Trouble: " + e);
- }
- }
- public static void main(String args[]) {
- new CalculatorServer();
- }
- }
建立这个服务器程序,然后保存到你的目录下,并且编译它。
5、客户端
客户端源代码如下:
- //CalculatorClient.java
- import java.rmi.Naming ;
- import java.rmi.RemoteException ;
- import java.net.MalformedURLException ;
- import java.rmi.NotBoundException ;
- public class CalculatorClient {
- public static void main(String [] args) {
- try {
- Calculator c = (Calculator)
- Naming .lookup(
- "rmi://localhost
- /CalculatorService");
- System .out.println( c.sub(4, 3) );
- System .out.println( c.add(4, 5) );
- System .out.println( c.mul(3, 6) );
- System .out.println( c.div(9, 3) );
- }
- catch (MalformedURLException murle) {
- System .out.println();
- System .out.println(
- "MalformedURLException" );
- System .out.println(murle);
- }
- catch (RemoteException re) {
- System .out.println();
- System .out.println(
- "RemoteException" );
- System .out.println(re);
- }
- catch (NotBoundException nbe) {
- System .out.println();
- System .out.println(
- "NotBoundException" );
- System .out.println(nbe);
- }
- catch (
- java.lang.ArithmeticException
- ae) {
- System .out.println();
- System .out.println(
- "java.lang.ArithmeticException" );
- System .out.println(ae);
- }
- }
- }
6、运行RMI系统
现在我们建立了所有运行这个简单RMI系统所需的文件,现在我们终于可以运行这个RMI系统啦!来享受吧。
我们是在命令控制台下运行这个系统的,你必须开启三个控制台窗口,一个运行服务器,一个运行客户端,还有一个运行RMIRegistry。
首先运行注册程序RMIRegistry,你必须在包含你刚写的类的那么目录下运行这个注册程序。
>rmiregistry
好,这个命令成功的话,注册程序已经开始运行了,不要管他,现在切换到另外一个控制台,在第二个控制台里,我们运行服务器CalculatorService,因为RMI的安全 机制将在服务端发生作用,所以你必须增加一条安全 策略。以下是对应安全策略的例子
grant {
permission java.security.AllPermission "", "";
};
注意:这是一条最简单的安全策略,它允许任何人做任何事,对于你的更加关键性的应用,你必须指定更加详细安全策略。
现在为了运行服务端,你需要除客户类(CalculatorClient.class)之外的所有的类文件。确认安全策略在policy.txt文件之后,使用如下命令来运行服务器。
> java -Djava.security.policy=policy.txt CalculatorServer
这个服务器就开始工作了,把接口的实现加载到内存等待客户端的联接。好现在切换到第三个控制台,启动我们的客户端。
为了在其他的机器运行客户端程序你需要一个远程接口(Calculator.class) 和一个stub(CalculatorImpl_Stub.class)。 使用如下命令运行客户端
> java -Djava.security.policy=policy.txt CalculatorClient
如果所有的这些都成功运行,你应该看到下面的输出:
1
9
18
3
如果你看到了上面的输出,恭喜你,你成功了,你已经成功的创建了一个RMI系统,并且使他正确工作了。即使你运行在同一个计算机上,RMI还是使用了你的网络堆栈和TCP/IP去进行通讯,并且是运行在三个不同的Java虚拟机上。这已经是一个完整的RMI系统
发表评论
-
Moto官方GMS谷歌服务套件For XT800+下载和使用教程
2011-05-21 22:03 4010MOTOXT800+ ANDROID ROM address: ... -
barcode4j
2011-05-14 17:34 976project net address: htt ... -
org.logicalcobwebs.proxool 连接池异常
2011-05-09 10:02 77062011/05/09 09:59:44:695 ERROR [ ... -
Spring JDBC 调用 procedure
2011-03-25 16:12 1342import java.sql.CallableStateme ... -
JDBC Call MySQL Proc
2011-03-25 15:10 1032MySQL PROC : ------------- ... -
Axis 开发WebService
2011-03-14 16:11 897net address : http://blog.cs ... -
java 内存查看软件_Jprofiler
2011-03-04 14:34 897java 内存查看软件(Eclipse plugin): ... -
了解 Eclipse 插件如何使用 OSGi
2011-02-18 09:39 986http://www.ibm.com/developerwor ... -
tomcat out of Memory error
2011-01-28 17:03 1031net address: http://www.iteye.c ... -
bak_
2010-12-30 17:48 814weblog address: http://kenwubl ... -
jsp tag page plugin
2010-12-09 15:31 907jsp tag page plugin: http://ww ... -
page cache set
2010-12-02 17:03 844response.setHeader("Ca ... -
properties file editor
2010-11-28 14:26 887net address(多种语言在同一个表格中,容易排除遗漏属 ... -
判断浏览器的语言
2010-11-26 17:43 865*.jsp page : <% Lan ... -
属性文件编辑器
2010-11-26 14:43 964在此想和大家分享一个不错的编写properties文件的Ecl ... -
google-api-translate-java
2010-11-14 17:51 815// http://code.google.com/p/go ... -
regex in java
2010-11-14 16:06 912Pattern类: 例子: Pat ... -
EHCache 配置详解
2010-10-13 17:22 10558EHCache 是一个纯java 的在进程中的缓存 ... -
displaytag jsp paging tag
2010-10-13 10:04 882displaytag :jsp paging tag ... -
Spring_Recipes code
2010-09-29 23:47 717code source: http://www.apress ...
相关推荐
RMI(Remote Method Invocation,远程方法调用)是Java平台中的一个重要特性,它允许Java对象在不同的Java虚拟机之间进行通信,实现分布式计算。RMI是Java开发分布式应用程序的基础,尤其在构建分布式服务和微服务...
Java RMI(远程方法调用)是Java编程语言中的一项核心技术,自JDK 1.1版本起就被引入,用于构建分布式系统。RMI允许Java对象在不同的Java虚拟机(JVMs)之间进行交互,仿佛这些对象是在同一台机器上一样。这种技术的...
Java RMI(Remote Method Invocation,远程方法调用)是Java平台提供的一种分布式计算技术,它允许Java对象在不同的网络环境中进行交互,就像它们在同一个进程内一样。RMI是Java在分布式系统领域的核心特性,极大地...
**RMI规范与详解** Java Remote Method Invocation (RMI)是一种强大的技术,它允许程序员创建分布式应用程序,使得不同Java虚拟机(JVM)之间的对象能够相互通信,即使它们位于不同的计算机上。RMI的核心概念是远程...
根据提供的文件信息,我们可以深入探讨Java RMI(Java Remote Method Invocation)的相关知识点,包括其概念、原理、体系结构以及一个具体的示例。 ### RMI的概念 RMI是一种Java技术,它允许开发者创建分布式应用...
### Java RMI (Remote Method Invocation) 概念与实践 #### 一、Java RMI简介 Java RMI(Remote Method Invocation)是一种允许调用不同Java虚拟机(JVM)上方法的机制。这些JVM可能位于不同的机器上,也可能在同一...
Java Remote Method Invocation (RMI) 是Java平台提供的一种分布式计算技术,它允许Java对象在不同的网络环境中进行交互,实现远程方法调用。本压缩包文件"rmi-code"包含了一个完整的RMI测试代码示例,适合在Linux和...
Spring Remote Method Invocation(RMI)是Java平台上的一个远程对象调用框架,它允许一个Java对象在一台机器上执行,并且被另一台机器上的客户端调用。在这个"SpringRMI小例子"中,我们将深入探讨如何利用Spring...
在Spring框架中,远程方法调用(Remote Method Invocation, RMI)是一种使应用程序能够通过网络调用另一个JVM上的对象方法的技术。RMI是Java平台的一部分,它允许开发者创建分布式应用,使得对象可以像调用本地方法...
**远程方法调用(Remote Method Invocation,RMI)** RMI是Java平台中用于实现分布式计算的一种机制。它允许一个Java对象在某台计算机上执行方法,而该方法的调用者位于另一台计算机上。这使得开发者可以构建分布式...
**RMI原理及应用详解** 远程方法调用(Remote Method Invocation,简称RMI)是Java平台提供的一种分布式计算技术,允许在不同的Java虚拟机(JVM)之间进行对象方法的透明调用。RMI的核心思想是使Java对象能够跨越...
Spring RMI(Remote Method Invocation)是Java平台上的远程方法调用技术,结合Spring框架的特性,使得在分布式系统中调用远程服务变得更加便捷。在这个简单的例子中,我们将深入理解Spring RMI的工作原理以及如何...
Java RMI(Remote Method Invocation,远程方法调用)是Java平台提供的一种分布式计算技术,它允许在不同的Java虚拟机之间进行远程对象的调用。RMI使得开发者可以像调用本地对象一样调用网络上的对象,极大地简化了...
Java RMI(Remote Method Invocation,远程方法调用)是Java平台提供的一种分布式计算技术,它允许在不同的Java虚拟机之间进行方法调用,仿佛这些对象都在同一台机器上。RMI是Java网络编程的重要组成部分,使得开发...
Java RMI (Remote Method Invocation) 是一种用于在Java应用程序之间进行远程通信的技术。为了提高RMI通信的安全性,我们可以使用SSL (Secure Sockets Layer) 或其后继者TLS (Transport Layer Security) 进行加密。...
本项目实例是基于RMI技术实现的一个服务器端程序,名为"RMIServer",提供了远程服务的接口和实现,下面将详细介绍RMI的基本概念、工作原理以及如何通过这个项目实例来学习和应用RMI。 1. **RMI基本概念**: - **...
Java RMI(Remote Method Invocation,远程方法调用)是Java平台提供的一种机制,用于构建分布式应用程序,使得在不同 JVM(Java虚拟机)上的对象能够像调用本地方法一样调用远程对象的方法。以下是对RMI的详细理解...
RMI(Remote Method Invocation,远程方法调用)是Java平台中的一个重要特性,它允许Java对象在不同的网络节点之间进行通信,实现分布式计算。这个“RMI入门好例子”旨在帮助初学者理解并实践RMI的基本原理和操作...
《Synaptics RMI3 触摸芯片编程详解——基于S3508》 Synaptics公司作为全球领先的触控解决方案供应商,其RMI(Remote Input Interface)系列芯片在业界有着广泛的应用。RMI3是Synaptics推出的一种新型接口,而S3508...
根据给定的文件信息,我们可以深入探讨RMI(Remote Method Invocation)在Java中的应用与实践。RMI是一种允许对象请求并远程执行位于不同虚拟机上的对象的方法的技术,它为Java应用程序提供了一种分布式计算能力。...