fbpx
Wikipedia

Java remote method invocation

In computing, the Java Remote Method Invocation (Java RMI) is a Java API that performs remote method invocation, the object-oriented equivalent of remote procedure calls (RPC), with support for direct transfer of serialized Java classes and distributed garbage-collection.

A typical implementation model of Java-RMI using stub and skeleton objects. Java 2 SDK, Standard Edition, v1.2 removed the need for a skeleton.

The original implementation depends on Java Virtual Machine (JVM) class-representation mechanisms and it thus only supports making calls from one JVM to another. The protocol underlying this Java-only implementation is known as Java Remote Method Protocol (JRMP). In order to support code running in a non-JVM context, programmers later developed a CORBA version.

Usage of the term RMI may denote solely the programming interface or may signify both the API and JRMP, IIOP, or another implementation, whereas the term RMI-IIOP (read: RMI over IIOP) specifically denotes the RMI interface delegating most of the functionality to the supporting CORBA implementation.

The basic idea of Java RMI, the distributed garbage-collection (DGC) protocol, and much of the architecture underlying the original Sun implementation, come from the "network objects" feature of Modula-3.

Generalized code Edit

The programmers of the original RMI API generalized the code somewhat to support different implementations, such as a HTTP transport. Additionally, the ability to pass arguments "by value" was added to CORBA in order to be compatible with the RMI interface. Still, the RMI-IIOP and JRMP implementations do not have fully identical interfaces.

RMI functionality comes in the package java.rmi, while most of Sun's implementation is located in the sun.rmi package. Note that with Java versions before Java 5.0 developers had to compile RMI stubs in a separate compilation step using rmic. Version 5.0 of Java and beyond no longer require this step.

Jini version Edit

Jini offers a more advanced version of RMI in Java. It functions similarly but provides more advanced security, object discovery capabilities, and other mechanisms for distributed object applications.[1]


Example Edit

The following classes implement a simple client-server program using RMI that displays a message.

RmiServerIntf interface
defines the interface that is used by the client and implemented by the server.
import java.rmi.Remote; import java.rmi.RemoteException; public interface RmiServerIntf extends Remote {  String getMessage() throws RemoteException; } 
RmiServer class
listens to RMI requests and implements the interface which is used by the client to invoke remote methods.
import java.rmi.Naming; import java.rmi.RemoteException; import java.rmi.server.UnicastRemoteObject; import java.rmi.registry.*; public class RmiServer extends UnicastRemoteObject implements RmiServerIntf {  public static final String MESSAGE = "Hello World";  public RmiServer() throws RemoteException {  super(0); // required to avoid the 'rmic' step, see below  }  public String getMessage() {  return MESSAGE;  }  public static void main(String args[]) throws Exception {  System.out.println("RMI server started");  try { //special exception handler for registry creation  LocateRegistry.createRegistry(1099);  System.out.println("java RMI registry created.");  } catch (RemoteException e) {  //do nothing, error means registry already exists  System.out.println("java RMI registry already exists.");  }    //Instantiate RmiServer  RmiServer server = new RmiServer();  // Bind this object instance to the name "RmiServer"  Naming.rebind("//localhost/RmiServer", server);  System.out.println("PeerServer bound in registry");  } } 
RmiClient class
this is the client which gets the reference (a proxy) to the remote object living on the server and invokes its method to get a message. If the server object implemented java.io.Serializable instead of java.rmi.Remote, it would be serialized and passed to the client as a value.[2]
import java.rmi.Naming; public class RmiClient {  public static void main(String args[]) throws Exception {  RmiServerIntf server = (RmiServerIntf)Naming.lookup("//localhost/RmiServer");  System.out.println(server.getMessage());  } } 

Before running this example, we need to make a 'stub' file for the interface we used. For this task we have the RMI compiler - 'rmic'

  • Note: we make a stub file from the '*.class' file with the implementation of the remote interface, not from the '*.java' file.
rmic RmiServer 

Note that since version 5.0 of J2SE support for dynamically generated stub files has been added, and rmic is only provided for backwards compatibility with earlier runtimes,[3] or for programs that don't provide an explicit port number (or zero) when exporting remote objects, which is required for generated stubs to be possible, as described in the Javadoc for UnicastRemoteObject. See the comment in the constructor above.

References Edit

  1. ^ Taylor, Ian J (2005). From P2P to Web Services and Grids : Peers in a Client/Server World. Computer Communications and Networks. London: Springer-Verlag. doi:10.1007/b138333. ISBN 1852338695. OCLC 827073874.[page needed]
  2. ^ Wilson, M. Jeff (November 10, 2000). "Get smart with proxies and RMI". JavaWorld. Retrieved 2020-07-18.
  3. ^ "Java RMI Release Notes". Oracle. Retrieved 9 May 2012.

External links Edit

  • "Remote Method Invocation Home". Oracle Technology Network for Java Developers. Redwood Shores, CA, USA: Oracle Corporation. Retrieved 2014-07-14.
  • The Java RMI tutorial - a good starting point to learn RMI. Also check the Hello World in RMI
  • the Java RMI online training - Very good for training JavaRMI and as reference
  • The RMI page in the JDK docs
  • java.rmi (Sun's Java API Reference for the RMI package)
  • Ann Wollrath; Roger Riggs; Jim Waldo. "A Distributed Object Model for the Java System" (PDF). Archived (PDF) from the original on 2022-10-10. Retrieved 2009-02-11.
  • Programming WebLogic RMI - an introduction to RMI in Oracle Weblogic.
  • General Remote Method Invocation

java, remote, method, invocation, computing, java, remote, method, invocation, java, java, that, performs, remote, method, invocation, object, oriented, equivalent, remote, procedure, calls, with, support, direct, transfer, serialized, java, classes, distribut. In computing the Java Remote Method Invocation Java RMI is a Java API that performs remote method invocation the object oriented equivalent of remote procedure calls RPC with support for direct transfer of serialized Java classes and distributed garbage collection A typical implementation model of Java RMI using stub and skeleton objects Java 2 SDK Standard Edition v1 2 removed the need for a skeleton The original implementation depends on Java Virtual Machine JVM class representation mechanisms and it thus only supports making calls from one JVM to another The protocol underlying this Java only implementation is known as Java Remote Method Protocol JRMP In order to support code running in a non JVM context programmers later developed a CORBA version Usage of the term RMI may denote solely the programming interface or may signify both the API and JRMP IIOP or another implementation whereas the term RMI IIOP read RMI over IIOP specifically denotes the RMI interface delegating most of the functionality to the supporting CORBA implementation The basic idea of Java RMI the distributed garbage collection DGC protocol and much of the architecture underlying the original Sun implementation come from the network objects feature of Modula 3 Contents 1 Generalized code 2 Jini version 3 Example 4 References 5 External linksGeneralized code EditThe programmers of the original RMI API generalized the code somewhat to support different implementations such as a HTTP transport Additionally the ability to pass arguments by value was added to CORBA in order to be compatible with the RMI interface Still the RMI IIOP and JRMP implementations do not have fully identical interfaces RMI functionality comes in the package java rmi while most of Sun s implementation is located in the sun rmi package Note that with Java versions before Java 5 0 developers had to compile RMI stubs in a separate compilation step using b rmic b Version 5 0 of Java and beyond no longer require this step Jini version EditJini offers a more advanced version of RMI in Java It functions similarly but provides more advanced security object discovery capabilities and other mechanisms for distributed object applications 1 Example EditThe following classes implement a simple client server program using RMI that displays a message RmiServerIntf interface defines the interface that is used by the client and implemented by the server import java rmi Remote import java rmi RemoteException public interface RmiServerIntf extends Remote String getMessage throws RemoteException RmiServer class listens to RMI requests and implements the interface which is used by the client to invoke remote methods import java rmi Naming import java rmi RemoteException import java rmi server UnicastRemoteObject import java rmi registry public class RmiServer extends UnicastRemoteObject implements RmiServerIntf public static final String MESSAGE Hello World public RmiServer throws RemoteException super 0 required to avoid the rmic step see below public String getMessage return MESSAGE public static void main String args throws Exception System out println RMI server started try special exception handler for registry creation LocateRegistry createRegistry 1099 System out println java RMI registry created catch RemoteException e do nothing error means registry already exists System out println java RMI registry already exists Instantiate RmiServer RmiServer server new RmiServer Bind this object instance to the name RmiServer Naming rebind localhost RmiServer server System out println PeerServer bound in registry RmiClient class this is the client which gets the reference a proxy to the remote object living on the server and invokes its method to get a message If the server object implemented java io Serializable instead of java rmi Remote it would be serialized and passed to the client as a value 2 import java rmi Naming public class RmiClient public static void main String args throws Exception RmiServerIntf server RmiServerIntf Naming lookup localhost RmiServer System out println server getMessage Before running this example we need to make a stub file for the interface we used For this task we have the RMI compiler rmic Note we make a stub file from the class file with the implementation of the remote interface not from the java file rmic RmiServer Note that since version 5 0 of J2SE support for dynamically generated stub files has been added and rmic is only provided for backwards compatibility with earlier runtimes 3 or for programs that don t provide an explicit port number or zero when exporting remote objects which is required for generated stubs to be possible as described in the Javadoc for UnicastRemoteObject See the comment in the constructor above References Edit Taylor Ian J 2005 From P2P to Web Services and Grids Peers in a Client Server World Computer Communications and Networks London Springer Verlag doi 10 1007 b138333 ISBN 1852338695 OCLC 827073874 page needed Wilson M Jeff November 10 2000 Get smart with proxies and RMI JavaWorld Retrieved 2020 07 18 Java RMI Release Notes Oracle Retrieved 9 May 2012 External links Edit Remote Method Invocation Home Oracle Technology Network for Java Developers Redwood Shores CA USA Oracle Corporation Retrieved 2014 07 14 The Java RMI tutorial a good starting point to learn RMI Also check the Hello World in RMI the Java RMI online training Very good for training JavaRMI and as reference The RMI page in the JDK docs java rmi Sun s Java API Reference for the RMI package Ann Wollrath Roger Riggs Jim Waldo A Distributed Object Model for the Java System PDF Archived PDF from the original on 2022 10 10 Retrieved 2009 02 11 Programming WebLogic RMI an introduction to RMI in Oracle Weblogic General Remote Method Invocation Retrieved from https en wikipedia org w index php title Java remote method invocation amp oldid 1171293727, wikipedia, wiki, book, books, library,

article

, read, download, free, free download, mp3, video, mp4, 3gp, jpg, jpeg, gif, png, picture, music, song, movie, book, game, games.