JAVA RMI例子

RMI 是java语言的一个RPC框架,本文给出基础例子如下:

1、实现接口:

public interface ICalc extends Remote {
    public int add(int param1, int param2) throws java.rmi.RemoteException;
}

2、服务端实现该接口:

复制代码
public class CalcImpl extends UnicastRemoteObject implements ICalc {

    protected CalcImpl() throws RemoteException {
        super();
    }

    @Override
    public int add(int param1, int param2) {
        return param1 + param2;
    }

    public static void main(String[] args) {
        ICalc calc;
        try {
            //下述代码主要解决connect confused问题
            System.setProperty("java.rmi.server.hostname", "192.168.0.16");
            calc = new CalcImpl();
            LocateRegistry.createRegistry(1011);  
            java.rmi.Naming.rebind("rmi://192.168.0.16:1011/calc", calc);
        } catch (RemoteException e) {
            e.printStackTrace();
        } catch (MalformedURLException e) {
            e.printStackTrace();
        }
    }
}
复制代码

3、定义测试客户端:

复制代码
public class Client {

    public static void main(String[] args) {
        ICalc calc;
        try {
            calc = (ICalc) Naming.lookup("rmi://192.168.0.16:1011/calc");
            System.out.println(calc.add(2,3));
        } catch (MalformedURLException | RemoteException | NotBoundException e) {
            e.printStackTrace();
        }
    }
}
复制代码

4、测试执行顺序:

1、服务器端编译javac CalcImpl

2、生成桩文件rmic CalcImpl,目录下会新增CalcImpl_Stub;

3、执行rmiregister,注册该程序;

4、在新窗口启动服务 java CalcImpl;

5、将CalcImpl_Stub拷贝至客户端,执行java Client;此时客户端打印预算结果

posted @   Fredric_2013  阅读(314)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示