• RMI(二)——Java RMI协议开发


    from:http://bbs.star-bbs.net/viewthread.php?tid=53934
    Java RMI协议开发
    在Java的开发中,Web端只是以个较小的亮点,抛开HTTP协议,Java世界里还有很多比较牛×的技术,但做为J2EE的核心技术,RMI协议就显得由为重要,RMI对搞过EJB的人来说应该不陌生,但EJB是在RMI和CORBA的基础之上进行了封装(也就是RMI//IIOP),程序员往往不用接触底层.做为Java工程师,对J2EE最核心的技术-----EJB的心脏 RMI自然是要非常熟悉.

    RMI的编程模型是采用框架和桩的模式,基本原理如下:
    客户请求------>(rmi协议)---------->远程框架(注册机)------------>远程对象----------(处理)--------->结果返回到框架--------->客户

    1. 服务器端创建远程接口和实现远程接口的类
    2. 通过RMIC命令(%java_home%/bin/rmic.exe)来编译远程接口实现类从而生成 stub等文件.
    3. 运行 rmiregistry命令(%java_home%/bin/rmiregistry.exe) 来启动RMI远程注册机
    4. 向RMI注册机注册远程对象供客户端调用


    下面来个实实在在的例子,大家回去根据效果自己领悟,写理论我不在行

    1. 首先 建立以个远程接口 Mclaren.java
    package com.skylink.rmi;

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

    public interface Mclaren extends Remote{
    public String sayHello(String username) throws RemoteException;
    }

    2.建立以个远程接口实现类,来做为RMI服务提供方 MclarenServer.java
    package com.skylink.rmi;

    import java.rmi.RemoteException;
    import java.rmi.Naming;
    import java.rmi.server.UnicastRemoteObject;

    pulic class MclarenServer extends UnicastRemoteObject {
    public MclarenServer() throws RemoteException {
    super();
    }
    public void registry(String name){
    try{
    System.setSecurityManager(new RMISecurityManager());
    Naming.rebind(name,this);
    }catch(Exception e)[
    e.printStackTrace();
    }
    }
    public String sayHello(String username){
    return "输出为 : "+username;
    }
    }

    3 建立用来启动服务器的类 StartServer.java

    package com.skylink.rmi;
    public class StartServer{
    public static void main(String[] args){
    try{
    System.setSecurityManager(new RMISecurityManager());
    new MclarenServer().registry("//192.168.0.192:1099/Mclaren");
    System.out.println("服务已经注册..");
    }catch(Exception e){
    e.printStackTrace();
    }
    }

    *
    ……
    【阅读全文】
  • 相关阅读:
    14.1.1 使用InnoDB 表的好处:
    7.5.1 Point-in-Time Recovery Using Event Times 使用Event Times 基于时间点恢复
    7.5 Point-in-Time (Incremental) Recovery Using the Binary Log 使用binay log 基于时间点恢复
    7.4.1 Dumping Data in SQL Format with mysqldump
    7.3.2 Using Backups for Recovery 使用备份用于恢复
    7.3.1 Establishing a Backup Policy
    RR 和RC隔离问题
    mark
    weblogic12
    转一篇对EJB理解的文章
  • 原文地址:https://www.cnblogs.com/dkblog/p/1980820.html
Copyright © 2020-2023  润新知