一.创建RMI程序的6个步骤:
1、定义一个远程接口的接口,该接口中的每一个方法必须声明它将产生一个RemoteException异常。
2、定义一个实现该接口的类。
3、使用RMIC程序生成远程实现所需的残根和框架。
4、创建一个服务器,用于发布2中写好的类,在server中注册端口
5. 创建一个客户程序进行RMI调用。
下面是详细的说明
1、定义一个远程接口的接口,该接口中的每一个方法必须声明它将产生一个RemoteException异常。
package com.liuc.server.inter;
import java.rmi.RemoteException;
public interface Hello extends java.rmi.Remote // 需要从Remote继承
{
public String SayHello() throws RemoteException; // 需要抛出remote异常
}
2、定义一个实现该接口的类。
/*
* 生成Stub文件 -keepgenerated生成对应的class文件以及源文件
* cd F:\work\RMITest\WebContent\WEB-INF\classes
* rmic -keepgenerated com.liuc.server.inter.impl.HelloImpl
* 将HelloImpl_Stub考到对应目录下即可
*/
package com.liuc.server.inter.impl;
import java.rmi.RemoteException;
import java.rmi.server.UnicastRemoteObject;
import com.liuc.server.inter.Hello;
public class HelloImpl extends UnicastRemoteObject // 必须从UnicastRemoteObject 继承
implements Hello {
public HelloImpl() throws RemoteException // 需要一个抛出Remote异常的默认初始化方法
{
}
public String SayHello() // 这个是实现I_Hello接口的方法
{
return "Hello world !!";
}
}
3、使用RMIC程序生成远程实现所需的残根Stub 和 框架。
找到对应的class文件的路径参照HelloImpl里面的说明生成残根和框架,将源文件拷贝到HelloImpl相同的目录下
4、创建一个服务器,用于发布2中写好的类。
package com.liuc.server;
import java.rmi.Naming;
import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry;
import com.liuc.server.inter.Hello;
import com.liuc.server.inter.impl.HelloImpl;
public class RMI_Server {
public static void main(String[] args) {
try {
Registry r = LocateRegistry.getRegistry(9999);
if(r != null) r = LocateRegistry.createRegistry(9999);
Hello hello = new HelloImpl(); // 实例化要发布的类
Naming.rebind("rmi://127.0.0.1:9999/helloServer", hello); // 绑定RMI名称 进行发布
System.out.println("=== Hello server Ready === ");
} catch (Exception e) {
e.printStackTrace();
}
}
}
5. 创建一个客户程序进行RMI调用。
package com.liuc.client;
import java.rmi.Naming;
import com.liuc.server.inter.Hello;
public class RMI_Client {
public static void main(String[] args) {
try {
Hello hello = (Hello) Naming.lookup("rmi://127.0.0.1:9999/helloServer"); // 通过RMI名称查找远程对象
System.out.println(hello.SayHello()); // 调用远程对象的方法
} catch (Exception e) {
e.printStackTrace();
}
}
}
6、JRE中配置端口规则
此时如果你运行程序是会报错误的,需要在JRE中配置相应的端口规则
找到JRE的目录,我的目录是D:\Program\JDK1.6\jre\lib\security
打开java.policy文件,在最后添加下面的规则即可
grant {
permission java.net.SocketPermission "*:1024-65535","connect,accept";
permission java.net.SocketPermission "*:80","connect";
};
我是把所有可以使用的端口都开了,实际使用时候你可以根据需要只开指定的端口。
附件是工程的源代码文件
分享到:
相关推荐
【标题】:“RMI入门” 远程方法调用(Remote Method Invocation,简称RMI)是Java平台提供的一种用于在分布式环境中实现对象间通信的技术。RMI允许一个Java对象调用网络另一端的Java对象的方法,就像调用本地对象...
### J2EE电子商务系统开发从入门到精通——基于Struts和Hibernate技术实现 #### J2EE概论 **1.1 简单双层架构到复杂多层架构** - **1.1.1 双层(C/S)软件架构设计** - 双层架构(客户端/服务器架构,Client/...
当用户请求一个JSP页面时,Servlet容器首先将JSP页面转换成一个Servlet类,然后编译这个类,最后执行生成的Servlet实例,将结果返回给客户端。 #### 七、HTML表单元素 在Web开发中,HTML表单是非常重要的组成部分...
开发工具的选择同样重要,Eclipse、NetBeans、IntelliJ IDEA等都是优秀的Java IDE,它们提供了代码编辑、调试、构建等功能,极大地提高了开发效率。 #### 四、应用部署与配置:Tomcat中的webapps目录 在Tomcat中,...
《Dubbo分布式系统入门教学》 Dubbo是一个高性能、轻量级的开源Java RPC框架,由阿里巴巴开发并贡献给Apache基金会。它旨在提供一个简单、高效的服务治理解决方案,帮助开发者构建微服务架构。本教学课件将带领你...
Flex、LCDS(LiveCycle Data Services)和Java是构建富互联网应用程序(Rich Internet Applications, RIA)的...记得下载提供的"Flex + LCDS + Java 入门教程.pdf",里面会有详细步骤和代码示例帮助你逐步学习和实践。
- `lib`:包含运行Rifidi Edge Server所需的所有代码。 - `docs`:包含所有文档。 - `launchfiles`:包含启动文件,用于配置和运行Rifidi Edge Server。 - **设置开发环境**:首先需要安装必要的开发工具,如...
- **负载均衡**: Dubbo支持多种负载均衡策略,如随机、轮询、最少活跃调用等,确保请求能够合理地分配到各个服务实例。 - **线程模型**: 了解Dubbo的线程模型对于理解其性能影响至关重要。 - **直连提供者、只订阅...
#### 二、DWR入门 **1.1 简介** DWR是一款强大的工具,用于构建高度交互式的Web应用程序。它通过提供一种简单的方式来实现客户端与服务器之间的通信,从而简化了开发流程。为了有效地使用DWR,开发者应该具备一定...
#### 二十四、远程网络复制调试(Remote Network Replication Debugging: RMI Replicated Caches) 当使用RMI实现远程网络复制时,可能会遇到各种问题。这部分内容提供了如何调试RMI复制缓存的具体方法。 #### 二十...
DWR的创新之处在于它的"Reverse AJAX"技术,它自动生成基于Java类的JavaScript代码,使得开发者可以在JavaScript中无缝使用Java代码,同时保持Java代码在服务器端运行并能访问服务器资源。为了安全,开发者需要配置...
**DWR(Direct Web Remoting)**是一种Java技术,它允许Web应用程序在客户端JavaScript和服务器端Java代码之间进行直接的远程方法调用(RMI)。这个技术极大地简化了富Internet应用程序(RIA)的开发,因为它提供了...
为了使`HelloWorldService`实例可用,我们还需要一个JMX连接器,如RMI(远程方法调用)JMX连接器,它允许远程管理工具连接到`MBeanServer`。配置连接器通常涉及修改`jmxremote`相关的系统属性或使用特定的启动参数。...