rmi|简单实例

本文介绍了一种使用Java RMI实现远程方法调用的技术。主要包括创建远程接口、实现该接口的类、设置远程调用的注册中心以及客户端如何连接并调用远程方法。通过实例演示了整个远程调用的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Remote接口: 用于标识可以一个类或接口,被标识的类或接口的方法可以被非本地JVM调用。即运行在服务器JVM中被Remote标识类或接口的方法,可以被运行在客户端JVM中类调用。

1 创建被Remote标识的类,即被客户端远程调用的类

package com.demo.rmi;

import java.io.Serializable;
import java.rmi.Remote;

// 实现序列化接口是因为:被调用对象在网络上返回了对象,网络传输对象需要先序列化对象
public class IRemoteImpl  implements Remote,Serializable {

    public String show() throws RuntimeException {
        System.out.println("进入");
        System.out.println(this.toString());
        return "远程调用成功";
    }
}

2 在客户端创建被远程调用对象的“注册中心”

package com.demo.rmi;

import java.net.MalformedURLException;
import java.rmi.AlreadyBoundException;
import java.rmi.RemoteException;
import java.rmi.registry.LocateRegistry;
import java.rmi.registry.Registry;
import java.util.Scanner;

public class ServerTest{

    public static void main(String[] args) throws MalformedURLException, RemoteException, AlreadyBoundException, InterruptedException {
        IRemoteImpl r = new IRemoteImpl();
        Registry registry = LocateRegistry.createRegistry(1234);
        registry.bind("rmi",r);
        System.out.println(r.toString());
        // 这行代码是为了:让注册中心启动后,不会马上停止
        new Scanner(System.in).nextLine();
    }
}

3 创建客户端类调用远程对象

package com.demo.rmi;

import java.net.MalformedURLException;
import java.rmi.Naming;
import java.rmi.NotBoundException;
import java.rmi.RemoteException;

public class ClientTest{

    public static void main(String[] args) throws MalformedURLException, RemoteException, NotBoundException {
        IRemoteImpl iRemote = (IRemoteImpl) Naming.lookup("rmi://127.0.0.1:1234/rmi");
        String string = iRemote.show();
        System.out.println(string);
    }
}

4 测试

先运行注册中心,在运行客户端。

注册中心运行结果:
注册中心运行结果
客户端运行结果:
客户端运行结果

远程调用成功。

5 总结

  1. 在服务器中,创建被Remote标识的类或接口,用于被远程调用。
  2. 在客户端中,创建注册中心。
  3. 在客户端中,创建调用类,调用远程对象。

END

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值