RMI JDK

  1. 创建接口
/**
 * 定义一个远程接口,必须继承Remote接口
 */
public interface HelloService extends Remote
{
    /**
     * 需要远程调用的方法必须抛出RemoteException异常
     * @param msg
     * @return
     * @throws RemoteException
     */
    String sayHello(String msg) throws RemoteException;
}

2.创建实现类

/**
 * 远程的接口的实现.
 */
public class HelloServiceImpl extends UnicastRemoteObject implements HelloService
{

    /**
     *  因为UnicastRemoteObject的构造方法抛出了RemoteException异常,
     *  因此这里默认的构造方法必须写,必须声明抛出RemoteException异常
     * @throws RemoteException
     */
    public HelloServiceImpl() throws RemoteException {
    }

    /**
     * 业务实现方法
     * @param msg
     * @return
     * @throws RemoteException
     */
    public String sayHello(String msg) throws RemoteException {
        return "server received the msg : " + msg;
    }
}

3.创建启动服务

/**
 * 创建RMI注册表,
 * 启动RMI服务,
 * 并将远程对象注册到RMI注册表中。
 */
public class HelloServer
{
    public static void main(String[] args)
    {
        try
        {
            //创建一个远程对象
            HelloService helloService = new HelloServiceImpl();

            //本地主机上的远程对象注册表Registry的实例,并指定端口为8888.
            // 这一步必不可少(Java默认端口是1099),必不可缺的一步.
            // 缺少注册表创建,则无法绑定对象到远程注册表上
            LocateRegistry.createRegistry(9123);

            //把远程对象注册到RMI注册服务器上,并命名为hello
            //绑定的URL标准格式为:rmi://host:port/name(其中协议名可以省略)
            Naming.bind("rmi://localhost:9123/hello", helloService);

            System.err.println("==========远程对象绑定成功============");
        } catch (RemoteException e) {
            System.err.println("创建远程对象发生异常!");
            e.printStackTrace();
        } catch (MalformedURLException e) {
            System.out.println("发生URL畸形异常!");
            e.printStackTrace();
        } catch (AlreadyBoundException e) {
            System.out.println("发生重复绑定对象异常!");
            e.printStackTrace();
        }

    }
}

4.创建客户端

/**
 * 在客户端调用远程对象上的远程方法
 */
public class HelloClient
{
    public static void main(String[] args)
    {
        try
        {
            //在RMI服务注册表中查找名称为helloService的对象,并调用其上的方法
            HelloService helloService 
            =(HelloService) Naming.lookup("rmi://localhost:9123/hello");

            System.out.println(helloService.sayHello("测试"));
        } catch (NotBoundException e) {
            e.printStackTrace();
        } catch (MalformedURLException e) {
            e.printStackTrace();
        } catch (RemoteException e) {
            e.printStackTrace();
        }
    }
}

注:RMI要求服务端和客户端的编写语言都是java.如果需要跨语言,则建议使用webservice.

参考地址:http://docs.oracle.com/javase/6/docs/technotes/guides/rmi/hello/hello-world.html

时间: 2024-10-24 13:37:34

RMI JDK的相关文章

分布式软件架构

刚接触,暂时没有什么实质内容,会慢慢补充 这些分布式架构主要解决的问题是:如何让客户端调用服务器端的远程对象的方法 (1)RMI JDK,要求客户端和服务器端都是java程序 (2)CORBA (3)Web服务 CORBA和Web服务允许用任意编程语言编写的客户程序与服务器程序相互通信

(转) Java 9学习笔记 (一)

reference: [1] http://www.cnblogs.com/IcanFixIt/p/7278696.html 一. JDK and JRE 在 Java SE 9之前,JDK中: bin目录用于包含命令行开发和调试工具,如javac,jar和javadoc. 它还用于包含Java命令来启动Java应用程序. include目录包含在编译本地代码时使用的C/C++头文件. lib目录包含JDK工具的几个JAR和其他类型的文件. 它有一个tools.jar文件,其中包含javac编译

Java——RMI

之前分布式系统调用用的是比较老的EJB,当时还是作为服务调用方,去调用别的系统的服务.最近发现新公司里面,用的是RMI,查了下发现EJB的底层实现就是RMI,也算是熟悉了... 一,使用JDK 中的RMI实现服务发布和引用 服务端接口: /** * Created by LiuHuiChao on 2016/11/18. */ public interface UserInfoService extends Remote{ /** * 定义远程接口,必须继承Remote接口, * 其中所有需要远

普通Java程序员学习使用的6个JDK内建工具

与你的问题不同,我认为软件工程主要是用来解决问题的.有些博客认为“每个小孩都应该学习编程”,“你认为学数学只是玩玩而已?如果你有看过我的HTML5调试器的话,你会发现我是一个程序员,但我做的工作远不止数学这些”. 上面两者都同意一个观点,软件工程不只是用计算机语言写的一些只言片语.软件解决的问题诠释了程序员的价值. 解决问题的最终进展来自科学.强化清晰的头脑和我们一路以来使用的工具. 你有没有留意过那些 JDK 安装附带的工具?既然那些大牛同意把那些工具加到 JDK 里,应该是有用的. 因此,在

JDK性能监控工具

JDK命令行工具 jps:JVM Process Status Tool,显示指定系统内所有的HotSpot虚拟机进程,可以通过RMI协议查询开启了RMI服务的远程虚拟机进程状态 jps [options] [hos tid] 列出正在运行的虚拟机进程,显示执行主类,以及虚拟机的唯一ID(Local Virtual Machine Identifier,LVMID),启动参数等 jstat:JVM Statisitcs Monitoring Tool,用于收集HtoSpot虚拟机各方面的运行数据

java RMI入门指南

感觉这篇文章不错,直接转了 RMI全称是Remote Method Invocation-远程方法调用,Java RMI在JDK1.1中实现的,其威力就体如今它强大的开发分布式网络应用的能力上,是纯Java的网络分布式应用系统的核心解决方式之中的一个.事实上它能够被看作是RPC的Java版本号.可是传统RPC并不能非常好地应用于分布式对象系统.而Java RMI 则支持存储于不同地址空间的程序级对象之间彼此进行通信.实现远程对象之间的无缝远程调用. RMI眼下使用Java远程消息交换协议JRMP

JAVA RMI分布式原理和应用

RMI(Remote Method Invocation)是JAVA早期版本(JDK 1.1)提供的分布式应用解决方案,它作为重要的API被广泛的应用在EJB中.随着互联网应用的发展,分布式处理任务也随之复杂起 来,WebService也得到普遍的推广和应用.        在某些方面,例如跨语言平台的分布式应用,RMI就显得力不从心了.在实际的应用中,是采用WebService还是传统的RMI来实现?这是一个需要权衡的问题,两者的比较如下所述:        1. 比起WebService,它

Java分布式处理技术(RMI,JDNI)

http://hedaoyuan.blog.51cto.com/4639772/813702 1.1 RMI的基本概念 1.1.1 什么是RMI RMI(Remote Method Invocation)远程方法调用是一种计算机之间对象互相调用对方函数,启动对方进程的一种机制,使用这种机制,某一台计算机上的对象在调用另外一台计算机上的方法时,使用的程序语法规则和在本地机上对象间的方法调用的语法规则一样. 1.1.2 RMI的用途 1. 分布式体系结构 我们为什么要使用分布式计算呢? Ø 当我们想

SUN JDK监控和故障处理工具

名称 主要作用 jps jvm process status tool,显示指定系统内所有的hotspot虚拟机进程 jstat jvm statistics monitoring tool,用于收集hotspot虚拟机各方面的运行数据 jinfo configuration info for java,显示虚拟机配置信息 jmap memory map for java,生成虚拟机的内存转储快照(heapdump文件) jhat jvm heap dump browser,用于分析heapma