RMI
(Remote Method Invocation)
In RMI, the server defines objects that the client can use remotely. The clients invoke methods of this remote object as if it were a local object running in the same machine as the client. RMI follows the principles of OOPS.
Comparison of Distributed and Non distributed Java Programs
Local Object Object Definition Object Implementation Object Creation Local object is defined by a Java class. A local object is implemented by its Java class. A new instance of a local object is created by the new operator. A local object is accessed directly via an object reference variable. In a single JVM, an object reference points directly at an object in the heap. Remote Object A remote object's exported behavior is defined by an interface that must extend the Remote interface. A remote object's behavior is executed by a Java class that implements the remote interface. A new instance of a remote object is created on the host computer with the new operator. A client cannot directly create a new remote object. A remote object is accessed via an object reference variable which points to a proxy stub implementation of the remote interface. A "remote reference" is a pointer to a proxy object (a "stub") in the local heap. That stub contains information that allows it to connect to a remote object, which contains the implementation of the methods.
Object Access
References
Comparison of Distributed and Non distributed Java Programs
Local Object Active References In a single JVM, an object is considered "alive" if there is at least one reference to it. Remote Object A remote object is considered to have an active remote reference to it if it has been accessed within a certain time period (the lease period). If all remote references have been explicitly dropped, or if all remote references have expired leases, then a remote object is available for distributed garbage collection. If a remote object implements the Unreferenced interface, the unreferenced method of that interface is called when all remote references have been dropped. The distributed garbage collector works with the local garbage collector. If there are no remote references and all local references to a remote object have been dropped, then it becomes a candidate for garbage collection through the normal means. RMI forces programs to deal with any possible RemoteException objects that may be thrown.
Finalization
If an object implements the finalize() method, it is called before an object is reclaimed by the garbage collector. When all local references to an object have been dropped, an object becomes a candidate for garbage collection. Exceptions are either Runtime exceptions or Exceptions. The Java compiler forces a program to handle all Exceptions
Garbage Collection
Exceptions
Java RMI Architecture
Interfaces RMI Architecture Layers Application Layer Stub and Skeleton Layer Remote Reference Layer Transport Layer
Java RMI Architecture (Interfaces)
The Heart of RMI The RMI architecture is based on one important principle: the definition of behavior and the implementation of that behavior are separate concepts. RMI allows the code that defines the behavior and the code that implements the behavior to remain separate and to run on separate JVMs. In RMI, the definition of a remote service is coded using an interface. The implementation of the remote service is coded in a class. Therefore, the key to understanding RMI is to remember that interfaces define behavior and classes define implementation.
Java RMI Architecture (Interfaces)
Java interface does not contain executable code. RMI supports two classes that implement the same interface. The first class is the implementation of the behavior, and it runs on the server. The second class acts as a proxy for the remote service and it runs on the client. A client program makes method calls on the proxy object. RMI sends the request to the remote JVM, and forwards it to the implementation. Any return values provided by the implementation are sent back to the proxy and then to the client's program.
Java RMI Architecture (Interfaces)
RMI Architecture Layers
Application Layer
Actual implementation of the client and the server programs. Calls are made to access and export remote objects Client can access the remote method through an interface that extends java.rmi.Remote. The remote methods are declared in one/more interfaces that extends java.rmi.Remote
Stub and Skeleton Layer
Stubs and skeletons are created using RMI compiler (RMIC).
Stub (Client side) Serializes any arguments to a remote method call and sends this information to server Receives any result from the remote method and returns it to the client
Skeleton (Server side) Receives remote method call and any arguments and deserializes the arguments Invokes appropriate method in server using these arguments Receives return value from this method call and sends this information back to the client.
Remote Reference Layer
The Remote Reference Layers defines and supports the invocation semantics of the RMI connection. This layer provides a RemoteRef object that represents the link to the remote service implementation object. This layer gets stream oriented data from transport layer and gives it to the proxy layer The stub objects use the invoke() method in RemoteRef to forward the method call. The RemoteRef object understands the invocation semantics for remote services.
Transport Layer
The Transport Layer makes the connection between JVMs. All connections are stream-based network connections. The RMI transport layer is designed to make a connection between clients and server. Manages communication between JVMs and transfers serialized objects between the remote reference layers of JVMs. Informs remote reference layer of methods it should invoke.
Naming Class
Clients find the remote objects by using a naming service. It uses the RMI registry that runs on each machine (by default on port 1099)that will host the remote service objects. A server registers the object with registry by calling the bind() or rebind() method of Naming Class. On the client side, the RMI registry is accessed through the lookup() method of Naming class. This class resides in the package java.rmi This class communicates with the registry running on the server to map the URLs to a particular remote object. Each entry in the registry has a name and an object reference. Client gives the name and gets back a reference to a remote object
Genesis of RMI
Define a remote interface Implement the remote interface Develop the server Develop a client Generate Stubs and Skeletons. Start the RMI registry. Start server. Start client
Steps to create a RMI system
Write and compile java code for interfaces. Write and compile java code for implementation class(Server). Generate stub and skeleton class files from implementation class by using the rmic compiler. Write and compile java code for the client program. Start the RMI Registry program on the server using the command start rmiregistry Run the RMI System by using the following commands. >java serverprog >java clientprog
Parameters in RMI
RMI supports method calls to remote objects. When these calls involve passing parameters or accepting a return value, how does RMI transfer these between JVMs? What semantics are used? Does RMI support pass-by-value or pass-by-reference? The answer depends on whether the parameters are primitive data types, objects, or remote objects.
Parameters in single JVM
The normal semantics for Java technology is pass-by-value. When a parameter is passed to a method, the JVM makes a copy of the value, places the copy on the stack and then executes the method. When the code inside a method uses a parameter, it accesses its stack and uses the copy of the parameter. Values returned from methods are also copies. When a primitive data type (boolean, byte, short, int, long, char, float, or double) is passed as a parameter to a method, the mechanics of pass-by-value are straightforward. The mechanics of passing an object as a parameter are more complex. An object resides in heap memory and is accessed through one or more reference variables. String s = "Test"; System.out.println(s); It is the reference variable that is passed to the method. In the example, a copy of reference variable s is made (increasing the reference count to the String object by one) and is placed on the stack. Inside the method, code uses the copy of the reference to access the object.
Primitive Parameters
When a primitive data type is passed as a parameter to a remote method, the RMI system passes it by value. RMI will make a copy of a primitive data type and send it to the remote method. If a method returns a primitive data type, it is also returned to the calling JVM by value. Values are passed between JVMs in a standard, machineindependent format. This allows JVMs running on different platforms to communicate with each other reliably.
Object parameters
When an object is passed to a remote method, the semantics change from the case of the single JVM. RMI sends the object itself, not its reference, between JVMs. It is the object that is passed by value, not the reference to the object. Similarly, when a remote method returns an object, a copy of the whole object is returned to the calling program. RMI uses a technology called Object Serialization to transform an object into a linear format that can then be sent over the network. Object serialization essentially flattens an object and any objects it references. Serialized objects can be de-serialized in the memory of the remote JVM and made ready for use by a Java program
Remote Object Parameters
RMI introduces a third type of parameter to consider: remote objects. A client program can obtain a reference to a remote object through the RMI Registry program. There is another way in which a client can obtain a remote reference, it can be returned to the client from a method call.
Distributed Garbage Collection
An automatic garbage collector that will reclaim the memory from any object that has been discarded by the running program. The interface to the DGC (distributed garbage collector) is hidden in the stubs and skeletons layer. However, a remote object can implement the java.rmi.server.Unreferenced interface and get a notification via the unreferenced method when there are no longer any clients holding a live reference. In addition to the reference counting mechanism, a live client reference has a lease with a specified time. If a client does not refresh the connection to the remote object before the lease term expires, the reference is considered to be dead and the remote object may be garbage collected. The lease time is controlled by the system property java.rmi.dgc.leaseValue. The value is in milliseconds and defaults to 10 minutes.