文档章节

Java RMI 远程调用简易教程

最爱肉肉
 最爱肉肉
发布于 2016/10/04 10:00
字数 542
阅读 84
收藏 0

这里分三步来讲,讲的比较繁琐.也是希望不会的人能尽可能看得懂.会的肯定不会看.OK,开始.

第一部分:服务器(生产者) 需要定义一个远程接口,以及实现该接口的类.

1.公共接口.

package com.pan.rmi.interf;

import java.rmi.Remote;
import java.rmi.RemoteException;

/**
 * Created by pan on 2016/10/4.
 */
public interface ServiceRemote extends Remote {
    //远程需要用到的方法
    String doSomething() throws RemoteException;
}

2.服务端实现接口(远程调用的类)

package com.pan.rmi.impl;

import com.pan.rmi.interf.ServiceRemote;
import java.rmi.RemoteException;
import java.rmi.server.UnicastRemoteObject;

/**
 * Created by pan on 2016/10/4.
 */
public class ServiceImple extends UnicastRemoteObject implements ServiceRemote {


    /**
     * 初始化抛出异常
     * @throws RemoteException
     * @since JDK1.1
     */
    public ServiceImple() throws RemoteException {
    }


    @Override
    public String doSomething() throws RemoteException {
        System.out.println("Service: A method is called !");
        return "Service doSomething .";
    }
}

3.启动服务端

package com.pan.rmi;

import com.pan.rmi.impl.ServiceImple;
import java.rmi.Naming;
import java.rmi.registry.LocateRegistry;

/**
 * Created by pan on 2016/10/4.
 */
public class Main {


    public static void main(String[] args) {
        try {
            ServiceImple service = new ServiceImple();
            //注册方法一
//            Registry registry = LocateRegistry.createRegistry(9889) ;
//            registry.rebind("myRemote", service);
            //注册方法二
            LocateRegistry.createRegistry(6600);
            Naming.rebind("rmi://127.0.0.1:6600/myRemote", service);
            System.out.println("服务器启动成功!");
        } catch (Exception e) {
            e.printStackTrace();
        }
    }
}

第二步:(将接口打包到客户端程序,可以用jar本地包,也可以使用maven本地仓库.)

第三步:(客户端代码调用服务端的方法)

package com.pan.rmi.client;


import com.pan.rmi.interf.ServiceRemote;

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

/**
 * Created by pan on 2016/10/4.
 */
public class ClientImpl {

    public static void main(String[] args) {
        try {
            //获取远程服务,这里注意一下端口必须跟服务端设置的一致
            ServiceRemote remote = (ServiceRemote) Naming.lookup("rmi://127.0.0.1:6600/myRemote");
            //调用远程方法
            String s = remote.doSomething();
            //输出
            System.out.println("客户端接受消息:" + s);
        } catch (NotBoundException e) {
            e.printStackTrace();
        } catch (MalformedURLException e) {
            e.printStackTrace();
        } catch (RemoteException e) {
            e.printStackTrace();
        }
    }


}

测试结果:

1.客户端

客户端接受消息:Service doSomething .

Process finished with exit code 0

2.服务端

服务器启动成功!
Service: A method is called !

 

 

题外:

RMI是Java内置的一种比较简单的远程调用方式,类是的还有apache的http远程调用.一般用于分布式服务器框架的proxy层,java作为一门高级语言.目前来说socket编程都比较的繁琐,更相对于底层通信(例如tcp/ip协议算法更是...),所以,一般来说都是使用成熟的框架去实现我们的需求.

© 著作权归作者所有

共有 人打赏支持
最爱肉肉
粉丝 3
博文 51
码字总数 34967
作品 0
深圳
程序员
RMI:Java中的分布式计算框架

RMI全称是Remote Method Invocation-远程方法调用,Java RMI在JDK1.1中实现的,其威力就体现在它强大的开发分布式网络应用的能力上,是纯Java的网络分布式应用系统的核心解决方案之一。其实...

qq_39521554
05/15
0
0
用RMI实现基于Java的分布式计算(1)

向您介绍使用RMI实现Java的分布式计算。由于Java具有跨平台、代码可移植性、安全高效等广泛而强大的功能,因而在开发网络Java分布式应用的时候,可以用它自身的机制实现分布式计算。 概述 随...

山哥
2012/02/24
0
0
Java RMI之HelloWorld篇

Java RMI 指的是远程方法调用 (Remote Method Invocation)。它是一种机制,能够让在某个 Java 虚拟机上的对象调用另一个 Java 虚拟机中的对象上的方法。可以用此方法调用的任何对象必须实现该...

方绍伟
2013/09/18
0
0
Java RMI那点事儿:初识HelloWorld

Java RMI 指的是远程方法调用 (Remote Method Invocation)。它是一种机制,能够让在某个 Java 虚拟机上的对象调用另一个Java 虚拟机中的对象上的方法。可以用此方法调用的任何对象必须实现该...

BazingaYou
2013/11/08
0
0
rmi经典实例---远程调用简单实现方式

Java RMI之HelloWorld篇 Java RMI 指的是远程方法调用 (Remote Method Invocation)。它是一种机制,能够让在某个 Java 虚拟机上的对象调用另一个 Java 虚拟机中的对象上的方法。可以用此方法...

霄羽
2015/08/06
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

异步化,高并发大杀器

今天来聊聊如何让项目异步化的一些事。 在进入正文之前,顺便给大家推荐一个Java架构方面的交流学习群:698581634,里面会分享一些资深架构师录制的视频录像:有Spring,MyBatis,Netty源码分...

Java大蜗牛
8分钟前
0
0
织梦dedecms安全设置

网站本身做好防范: 1、修改默认后台名。 打开网站根目录,找到[dede],这个文件夹就是后台的路径,可以随意修改,比如修改为[adminbuy],此时后台登陆的路径为:http://www.*****.com/admi...

雨季2014
8分钟前
0
0
完美Python入门基础知识点总结,看完你的Python就完全入门了!

Python标识符 在 Python 里,标识符有字母、数字、下划线组成。 在 Python 中,所有标识符可以包括英文、数字以及下划线(_),但不能以数字开头。 Python 中的标识符是区分大小写的。 以下划线...

糖宝lsh
14分钟前
0
0
Java关于前后台传输中文乱码以及Excel下载乱码解决

针对乱码,一般情况是前后台以及中间件编码格式不同导致.故需要保证编码格式相同即可. 1.前台页面格式指定,这里用的是jsp,故需要将pageEncoding指定为"UTF-8" 2.指定服务器编码格式,比如用的t...

勤奋的蚂蚁
17分钟前
0
0
Flutter组件 - Flexible

Flexible是一个控制Row、Column、Flex等子组件如何布局的组件。 Flexible组件可以使Row、Column、Flex等子组件在主轴方向有填充可用空间的能力(例如,Row在水平方向,Column在垂直方向),但是...

一箭落旄头
20分钟前
1
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部