Skip to main content

What is RMI? how does distributed application created using RMI? Explain with an example.

 RMI (Remote Method Invocation) is a Java API that enables distributed applications to communicate and interact with each other over a network. It allows Java objects to invoke methods on objects running on remote machines, just as if they were invoking methods on local objects.

In RMI, a client sends a request to a remote object, which then processes the request and sends a response back to the client. The communication between the client and the remote object is transparent to the developer, as the RMI system handles all the necessary details.

To create a distributed application using RMI, we need to follow these steps:

1. Define the remote interface:

The remote interface is a Java interface that declares the methods that can be invoked remotely by clients. These methods should throw RemoteException, which is a checked exception indicating that a remote error has occurred. The remote interface should extend the java.rmi.Remote interface.

2. Implement the remote interface:

The implementation of the remote interface should be provided by a class that extends java.rmi.server.UnicastRemoteObject. This class provides the necessary functionality to export the object and make it available for remote invocation.

3. Register the remote object:

The remote object should be registered with the RMI registry using the java.rmi.Naming class. The Naming class provides a simple way to bind remote objects to names in the registry.

4. Write the client code:

The client code should look up the remote object in the registry using the Naming class, cast it to the remote interface type, and then invoke the remote methods on it.


Example:

Let's consider a simple example of a calculator application that allows clients to perform arithmetic operations on two numbers using RMI.

1. Define the remote interface:

import java.rmi.*;
public interface Calculator extends Remote {
    public int add(int a, int b) throws RemoteException;
    public int subtract(int a, int b) throws RemoteException;
}

2. Implement the remote interface:

import java.rmi.*;
import java.rmi.server.*;
public class CalculatorImpl extends UnicastRemoteObject implements Calculator {
    public CalculatorImpl() throws RemoteException {}
    public int add(int a, int b) throws RemoteException {
        return a + b;
    }
    public int subtract(int a, int b) throws RemoteException {
        return a - b;
    }
}

3. Register the remote object:

import java.rmi.*;
public class CalculatorServer {
    public static void main(String[] args) {
        try {
            Calculator c = new CalculatorImpl();
            Naming.rebind("CalculatorService", c);
        } catch (Exception e) {
            System.out.println("Error: " + e);
        }
    }
}

4. Write the client code:

import java.rmi.*;
public class CalculatorClient {
    public static void main(String[] args) {
        try {
            Calculator c = (Calculator) Naming.lookup("CalculatorService");
            int sum = c.add(5, 10);
            int difference = c.subtract(5, 10);
            System.out.println("Sum: " + sum);
            System.out.println("Difference: " + difference);
        } catch (Exception e) {
            System.out.println("Error: " + e);
        }
    }
}

In this example, the server application registers the CalculatorImpl object with the RMI registry using the Naming class, and the client application looks up the CalculatorImpl object in the registry and invokes its remote methods.

Comments

Popular posts from this blog

Write a program using the algorithm count() to count how many elements in a container have a specified value.

 Here's an example program using the count() algorithm to count the number of occurrences of a specific value in a vector container: #include <iostream> #include <vector> #include <algorithm> using namespace std; int main() {     vector<int> numbers = { 2, 5, 3, 7, 8, 5, 1, 5, 4 };          // count the number of occurrences of the value 5 in the vector     int count = count(numbers.begin(), numbers.end(), 5);          cout << "The number of occurrences of 5 in the vector is: " << count << endl;          return 0; } Output: The number of occurrences of 5 in the vector is: 3 Explanation: The program starts by creating a vector named numbers that contains several integer values. The count() algorithm is used to count the number of occurrences of the value 5 in the numbers vector. The function takes three arguments: the beginning and end iterators of...

What are Stub and Skeleton in Distributed Application? Explain its function with block diagram.

 Stub and Skeleton are two important components of distributed applications. A distributed application is a software system that runs on multiple computers connected through a network. It allows users to access resources and services on different computers as if they were on a local computer. In a distributed application, a client program on one computer sends a request to a server program on another computer. The server program processes the request and sends a response back to the client program. Stub and Skeleton help to facilitate this communication between the client and server programs. A Stub is a client-side proxy that represents the remote object on the client machine. It acts as a gateway for the client to communicate with the server. When a client invokes a method on the Stub, it marshals the arguments and sends them to the server over the network. The Stub then waits for the server to send a response. When the response is received, the Stub unmarshals the data and retur...

Explain the lifecycle of Servlet with block diagram.

 The lifecycle of a Servlet can be divided into several stages. Here's a block diagram that illustrates the different stages: Servlet API: The Servlet API provides a standard set of interfaces and classes for creating and interacting with Servlets. It is typically included in the web application's classpath as a JAR file. Servlet Container: The Servlet Container is a web server or application server that implements the Servlet API. It provides a runtime environment for executing Servlets and manages their lifecycle. Servlet Class: The Servlet Class is the Java class that implements the javax.servlet.Servlet interface. It contains the logic for processing HTTP requests and generating HTTP responses. init(): The init() method is called once when the Servlet is first loaded by the Servlet Container. It is used for initialization tasks, such as setting up database connections, loading configuration settings, or initializing other resources that will be used by the Servlet. service(...